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W JACHRANCE O BAJTKU KSLEIESZASZU 


Ani się obejrzeliśmy, a  „Bajtek” 
wszedł w trzeci rok swego rozwoju. Za- 
czynaliśmy jako pionierzy — obecnie 
przybyło nam towarzystwo licznych pism 
i wydawnictw na tematy związane z in- 
formatyką. Zmieniły się w tym czasie 
realia rynku komputerowego w Polsce i 
uwarunkowania rozwojowe tej kluczo- 
wej skądinąd dziedziny współczesnej go- 
spodarki. Musimy więc również zmienić 
się i my. 

Przez dwa dni — od piątkowego popo- 
łudnia 18 marca poczynając — trwało w 
Jachrance spotkanie programowe dzien- 
nikarzy i współpracowników „Bajtka”. 
Bez taryfy ulgowej podsumowaliśmy 
dotychczasowe publikacje i działania 
naszego pisma. Nie ukrywamy, że bilans 
wypadł pozytywnie, choć i lista grzechów 
okazała się długa. Nie miejsce tu na 
szczegółowe ich relacjonowanie; najważ- 
niejsze dla Czytelnika jest przecież to, 
co będzie mógł spotkać w przyszłości na 
łamach „Bajtka”. I temu właśnie poświę- 
cona była większość naszych dyskusji w 
Jachrance. 

Bylibyśmy zarozumiali uważając, że 
potrafimy wszystkie problemy rozstrzy- 
gnąć w redakcyjnym gronie. Dlatego do 
naszej dyskusji zaprosiliśmy wypróbowa- 
nych sojuszników „Bajtka”. 

Długo pozostanie w pamięci wszyst- 
kich „bajtkowców” wielogodzinne spo- 
tkanie z profesorem Władysławem M. 
Turskim poświęcone, najogólniej mó- 
wiąc, współczesnym trendom rozwoju 
informatyki. Umówiliśmy się wcześniej 
z Profesorem na formułę spotkania we- 
wnętrznego, nie do publikacji więc, 
dotrzymując zobowiązania, nie będę 
składał relacji z dyskusji. Mogę jednak 
przekazać uwagę jednego z naszych kole- 
gów wypowiedzianą po spotkaniu: „Wy- 
starczy to nagrać i opublikować — a byłby 
bestseller!” W imieniu zespołu „Bajtka” 
zachęcam tą drogą Pana Profesora do 
napisania kolejnego hitu na wzór jego 
książki pt. „Nie samą informatyką”. To 
się sprzeda! A co ważniejsze — na to cze- 
ka młodzież! 

Z profesorem Turskim dyskutowaliśmy 
między innymi o granicach programowa- 
nia; natomiast granice technologii były 


wiodącym tematem spotkania z doc. dr 
hab. inż. Andrzejem Jakubowskim, kie- 
rownikiem Zakładu Mikroelektroniki na 
Wydziale Elektroniki Politechniki War- 
szawskiej. Najbardziej lapidarny wnio- 
sek z tego spotkania: w XXI wieku wej- 
dziemy jeszcze z technologią opartą na 
krzemie. Co będzie potem — to na razie 
temat na fascynującą powieść science-fic- 
tion, ale tylko na razie... 

Cywilizacyjne konsekwencje rewolucji 
informacyjnej przedstawił nam doc. dr 
hab. Lech Zachor z Uniwersytetu im. Ma- 
rii Curie-Skłodowskiej w Lublinie. Wróci- 
my do tego tematu na łamach „Bajtka”. 
Komputeryzacja nie jest przecież celem w 
sobie. Komputery dokonują rewolucji, a 
więc sterując rozwojem komputeryzacji 
można wpływać na przyspieszenie lub 
zwolnienie premier cywilizacyjnych. Na 
ile i pod jakimi warunkami jest to moż- 
liwe? 

O problemach zapewnienia dostaw 
taniego sprzętu mikrokomputerowego 
dyskutowaliśmy z dyrektorem Wojcie- 
chem Szanterem z Centralnej Składnicy 
Harcerskiej. W meandry wprowadzania 
informatyki do szkół wprowadzał nas 
profesor Kuran z warszawskiego LO im. 
Czackiego. Pani Irena Dańda z Fundacji 
„Pomoc dzieciom” zapoznała nas z do- 
tychczasowymi działaniami i doświad- 
czeniami w zakresie wykorzystania kom- 
puterów do pomocy dzieciom chorym... 

Każde z tych spotkań zaowocuje na 
łamach „Bajtka” różnorodnymi publika- 
cjami i akcjami. 

Oczywiście, odbyły się również „burze 
mózgów” i dyskusje na tematy dotyczące 
bezpośrednio naszego pisma. Również 
z udziałem przyjaciół „Bajtka” — redak- 
tora Jana Rurańskiego, znanego popu- 
laryzatora nauki i techniki oraz dyrek- 
tora Wiesława Falczaka z Młodzieżowej 
Agencji Wydawniczej. 

Spędziliśmy te dwa dni z Jachrance 
bardzo pracowicie. Na ile owocna była ta 
praca? To Czytelnicy będą mogli ocenić 
sami podczas lektury kolejnych numerów 
naszego pisma oraz wydań specjalnych 
„Bajtka” adresowanych do użytkowni- 
ków poszczególnych typów komputerów. 


Waldemar Siwiński 


SZANOWNY 
PANIE REDAKTORZE! 


Prenumeruję wasze pismo, pracuję z nim. Pra- 
cuje z „ Bajtkiem” także wielu moich kolegów i 
bardzo się nam on podoba. Szkoda, że nie moż- 
na go było w naszym kraju wcześniej prenume- 
rować, dobrze że doszedł do nas chociaż w 1988 
roku. 

W Związku Radzieckim pism o podobnym pro- 
filu niestety nie ma, chociaż zainteresowanie tą 
tematyką jest ogromne. Dlatego też „ Bajtek” jest 
dla nas tak aktualny. 


Ja i moi przyjaciele mamy do Was wielką proś- 
bę. Jeśli tylko macie taką możliwość przyślijcie 
nam pełny komplet egzemplarzy waszego pisma 
za 1986 i 1987 rok. 

Mamy wielką nadzieję, że nam pomożecie. 

Władimir Korbut 
Kijów 


Od red. Zgodnie z ogłoszeniem zamieszczo- 
nym w nr 2/88 będziemy kontynuowali wysyłkę 
(za zaliczeniem pocztowym) zaległych numerów 
„Bajtka”. Niestety nie wszystkie mamy do dyspo- 
zycji. Daremne pozostaną dla przykładu prośby o 
„Bajtka” „Tylko o Atari". 
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GRA O JUTRO 


Rozmowa z 


Mirosiawem 
Madejskim, 
przewodniczącym 
Rady Fundatorów 
fundacji 

„Pomoc 
Dzieciom”, 

szefem „Refleksu”. 


— Panie prezesie, skąd wziął się 
pomysł zorganizowania przez wła- 
ścicieli prywatnych przedsiębiorstw 
branży komputerowej instytucji cha- 
rytatywnej. Czyżby z niechęci do pła- 
cenia podatków? 

— Forma uczestnictwa w działalności 
charytatywnej jaką jest fundacja przyję- 
ta się dość powszechnie na świecie. W 
wielu krajach, takich jak np. Stany Zjed- 
noczone państwo, w ogóle, w niewielkim 
stopniu zajmuje się zabezpieczaniem 
potrzeb społecznych obywateli. Rolę tę 
przejmują właśnie rozliczne instytucje 
powołane przez osoby prywatne, spółki, 
konsorcja. U nas również Sejm dostrzegł 
potrzebę tworzenia fundacji. Uchwaleniu 
ustawy o fundacjach nie towarzyszyły 
jednak żadne zmiany w systemie podat- 
kowym. Tak więc łożąc na cel społeczny 
nie płacimy bynajmniej mniejszych po- 
datków. 

— A zatem — co kierowało funda- 
torami? 

— Myślę, że nade wszystko zami- 
łowanie do informatyki i właśnie chęć 
fundacji dzieciom. Przecież niezależnie 
od powołania samej fundacji, także w 
przeszłości „Refleks” pomagał wyposa- 
żać pracownie nformatyczne w sprzęt 
komputerowy, oddawał swoje laboratoria 
na zajęcia dla dzieci. A ludzie u nas pra- 
cujący za darmo zostawali wówczas po 
godzinach, by z nimi pracować. Smieją 
się z nas czasem, że inwestujemy w tak 
odległą przyszłość. 

Z drugiej strony szkoda nam było tro- 
chę rezygnować z produkcji tego wszyst- 
kiego, co już nie jest na rynku całkowitą 
nowością, lecz mogłoby się jeszcze z 
powodzeniem sprzedawać. W ofercie 
samego „Refleksu” na produkty te nie 
ma już miejsca, fundacja dla wsparcia 
swej działalności charytatywnej mogłaby 
nimi handlować. 

— A komu konkretnie będzie po- 
magać fundacja? 

— Nie mamy ambicji stworzenia ja- 
kiejś gigantycznej instytucji. Chcemy 
zaopiekować się tylko dwiema grupami 
dzieci. Pierwsza z nich składać się bę- 
dzie z dzieci niepełnosprawnych rucho- 
wo, lecz wykazujących predyspozycje 
intelektualne, nie tylko zresztą do samej 
informatyki. Docelowo z tego zespołu 
chcielibyśmy selekcjonować uzdolnio- 
nych w naukach ścisłych, ale także 

przyszłych grafików posługujących 
się komputerem. Dzięki fundacji będą 
oni mogli zdobyć zawód, stać się warto- 
ściowymi obywatelami. 

— Wspomniał pan o dwóch gru- 
pach. Kto znajdzie się w tej drugiej? 

— Młodzi ludzie o wybitnych uzdol- 
nieniach informatycznych. 

— Jakie widzi pan przed nimi za- 
dania? 

— Chcielibyśmy, by niejako „ciągnęli” 
oni tę pierwszą grupę. Poza tym, wydaje 
nam się, że mogliby brać czynny udział 
w opracowywaniu oprogramowania edu- 
kacyjnego, a w każdym razie je testo- 
wać. 

— Pisanie programów edukacyj- 
nych, to niełatwe zadanie. 

— Dlatego powierzyć je chcemy naj- 
lepszym. A że będą to tak młodzi ludzie? 


ŚMIEJĄ SIĘ Z NAS 


CZASEM, 


ŻE INWESTUJEMY _ 
W TAK DALEKĄ 
PRZYSZŁOŚĆA 


Na całym świecie największe problemy 
przy opracowywaniu programów eduka- 
cyjnych sprawiają scenariusze nie pa- 
sujące do wyobraźni uczniów. Dlatego 
właśnie najbardziej praktyczne byłoby 
chyba realizowanie tych zadań w ich 
obecności 

— Skąd fundacja znajdzie fundu- 
sze na swą działalność, gdzie znaj- 
dzie dla niej bazę lokalową i sprzęt? 

— Jak na razie cała działalność fun- 
dacji opiera się na darowiznach funda- 
torów. W najbliższym czasie rozpocznie 
ona jednak także własną działalność 
gospodarczą, w dziedzinach: handlu, re- 
klamy, informatyki i produkcji z tworzyw 
sztucznych. Mam nadzieję, że dochody z 
tej działalności pozwolą w całości sfinan- 
sować zajęcia z obiema wspomnianymi 
grupami. Planujemy nawet osiągnięcie 
pewnych nadwyżek, które przekazać 
chcielibyśmy m.in. fundacji „Złoty kłos” 
zajmującej się pomocą dzieciom chorym 
na celiakię. 

Sprzęt i lokale, jak na razie, udostęp- 
nił fundacji „Refleks”. W trakcie trwania 


wystawy KOMPUTER 88 zwróciliśmy się 
również do części wystawców o pomoc 
sprzętową. Żadna z polskich firm nie za- 
reagowała na nasz apel. Dla grupy mło- 
dzieży niepełnosprawnej lokale, miejmy 
nadzieję, udostępnią instytucje opieku- 
jące się tą młodzieżą niejako „z urzędu”. 
Otwarci jesteśmy także na inne propozy- 
cje, choćby ze strony szkół 

— A jak wyglądać będzie dobór 
uczestników obu wspieranych przez 
fundację grup. 

— Grupę niepełnosprawną utworzyć 
zamierzamy w oparciu o jakąś działają- 
cą instytucję opiekuńczą np. „Caritas”. 
Natomiast naboru do drugiej grupy do- 
konywać będziemy na różne sposoby. 
Uczymy m.in. na zgłaszanie nam kandy- 
datów przez ich nauczycieli bądź rodzi- 
ców. Myślę, że znaczną część spośród 
naszych przyszłych podopiecznych sta- 
nowić będą Czytelnicy „Bajtka”. Dlate- 
go też liczę na to, że dzięki informacji o 
powstaniu i działalności naszej fundacji 
pojawią się zgłoszenia od tych, którzy 
liczyliby na jej pomoc. 


— W takim razie proponujemy 
przysługa za przysługę. Gdy pod- 
opieczni fundacji na dobre rozwiną 
już swoją twórczość programistów 
mogliby na naszych lamach upo- 
wszechniać swoje dzieła. 

— Oczywiście, to jest możliwe. My- 
ślę, że dobrze byłoby gdyby właśnie w 
„Bajtku” najbardziej uzdolnieni młodzi 
14-15 letni informatycy znaleźli miejsca 
na przekazywania swoich idei. Byłoby to 
chyba tym cenniejsze, że zwracaliby się 
oni w waszym piśmie do swoich rówie- 
śników ich językiem. To byłyby szanse 
na stworzenie czegoś naprawdę unikal- 
nego 

— Oczekujemy więc w „ Bajtku „, 
na pisemne, telefoniczne lub osobiste 
zgłoszenia wszystkich zainteresowa- 
nych propozycją Fundacji. Panu dzię- 
kujemy nastomiast za rozmowę. 


Rozmawiał: 
Grzegorz Onichimowski 
Kazimierz Treger 
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Drukarkę_ Citizen _120-D 
otrzymaliśmy do testo- 
wania dzięki uprzejmości 
firmy „Synelec”. 


DRUKARKA 


Citizen 120-D to 9-igłowa półprofesjonalna 


drukarka mozaikowa 


rzeznaczona do współ- 


rac 


zarówno z domowymi 


komputerami 


8-bi- towymi (Amstrad, Atari, Commodore). jak 


i komputerami klasy IBM PC. 


BUDOWA I DZIAŁANIE 


Konstrukcja mechaniczna drukarki 
jest klasyczna i nie odbiega od innych 
urządzeń tej klasy. Możliwe jest uży- 
cie papieru perforowanego, z rolki i w 
arkuszach o szerokości od 76 do 250 
mm. Maksymalnie można uzyskać 
oryginał i dwie kopie. Dodatkowym 
wyposażeniem jest podajnik papieru 
perforowanego umieszczany ponad 
wałkiem i połączony z mechanizmem 
drukarki przez kółko zębate. W przy- 
padku zastosowania ażurowego sto- 
jaka możliwe jest podawanie papie- 
ru spod drukarki przez szczelinę w 
spodniej części obudowy. 

W bardzo interesujący sposób 
rozwiązano część elektroniczną dru- 
karki. Wszystkie układy oprócz bez- 
pośrednio sterujących pracą części 
mechanicznej zostały umieszczone 
na oddzielnej płytce wysuwanej jak 
szuflada z prawej strony obudowy. 
Znajduje się tam również gniazdo złą- 
cza Centronics. 

Głowica drukarki umieszczona 
została przed wałkiem na stalowej 
prowadnicy i przesuwana jest pa- 
skiem zębatym. Demontaż głowicy 
jest bardzo prosty. Taśma drukująca 
o szerokości 6 mm znajduje się w du- 
żej kasecie, a głowica przesuwa się 
między taśmą a kasetą. Prędkość 
druku wynosi w trybie draft 120 CPS 
(znaków na sekundę), a w trybie kore- 
spondencyjnym (NLQ) — 24 znaki na 
sekundę, jest więc nieco mniejsza niż 
w innych drukarkach. 

Znaki drukowane są z matrycy 9 
na 9 punktów w trybie draft oraz 17 
na 17 w trybie NLQ. Do dyspozycji 
są cztery podstawowe kroje pisma: 
Pica — 10 CPI (znaków na cal), Elitę 
— 12 CPI, Condensed Pica — 17 CPI 
i Condensed Elitę — 20 CPI. Odpo- 
wiednio uzyskuje się 80, 96, 136 i 160 
znaków w wierszu (na arkuszu A4). 
Dodatkowo można wykorzystać druk 
proporcjonalny, w którym liczba zna- 
ków zależy od ich rodzaju („i” zajmuje 
mniej miejsca niż np. „k”). 

Wszystkie kroje pisma mogą być 
pochylone (italics) lub drukowane w 
podwójnej szerokości (5, 6, 8,5 i 10 
CPI). Dodatkowo istnieją dwie możli- 
wości druku rzadko spotykane w tej 
klasie sprzętu: druk odwrócony (w 
negatywie) i druk powiększony pio- 
nowo (znaki o podwójnej wysokości). 
Różne gęstości pisma pokazuje rys. 
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1, aróżne odmiany kroju rys. 3. Przez 
odpowiedni wybór dodatkowych opcji 
można uzyskać różne warianty wyra- 
zistości druku (rys. 2). 

Wszystkie drukarki posiadają już 
standardowo odstęp wierszy 1/6, 1/8 
i 7/72 cala. Poza tym istnieje możli- 
wość dowolnego ustalenia odstępu z 
określonym krokiem. Większość firm 
stosuje programowany odstęp n/216 
cala, a firma Star n/144 cala. I tu Citi- 
zen ma przewagę, bowiem dysponuje 
obydwoma wariantami. 

Szczególnie bogate są możliwości 
Citizena w operowaniu odstępam1 
i tabulacjami. Mamy do dyspozycji 
poziomą tabulację stałą, zmienną i 
względną oraz względną i bezwzględ- 
ną tabulację punktową (określaną 
w punktach, a nie w znakach). Trzy 
pierwsze rodzaje dotyczą także ta- 
bulacji pionowej. Kolejną funkcją jest 
możliwość ustalania odstępu między 
znakami w zakresie od 0 do 127 punk- 
tów (rys. 4). Przy druku koresponden- 
cyjnym możliwe jest justowanie tekstu 
przez samą drukarkę (nie przez kom- 
puter). Do wyboru mamy centrowanie 
tekstu, justowanie do lewego lub pra- 


Drukarka Citizen 120-D 

Drukarka Citizen 120-D0 

Drukarka Citizen 120-D 

Drukarka Citizen 120-D 
Drukarka Citizen i20-D 
Drukarka Citizen 120-D 


IP eau kz 2a FT |--- 


Drukarka Citizen 120-D 

Drukarka Citizen 120—D 
Drukarka Citize=m 
[71 © i z" EFK" 


1=20—D 


1Z0—0D 


Rys. 1 


wego marginesu oraz justowanie do 
obu marginesów. 

Drukarka może pracować w stan- 
dardach Epson FX i IBM Graphics 
Printer. Standard wybierany jest 
przełącznikiem lub programowo — 
jest to pierwsza ze znanych mi dru- 
karek posiadająca możliwość prze- 
łączenia programowego. W trybie 
Epson do dyspozycji jest 96 znaków 
normalnych lub pochylonych oraz 11 
zestawów międzynarodowych po 12 
znaków w każdym. Poza tym moż- 
liwe jest uzyskanie zamiast kodów 
sterujących od 128 do 159 dodatko- 
wych 32 znaków graficznych. W try- 
bie IBM otrzymuje się pełny zestaw 
liczący 232 znaki. 

W obu trybach pracy (Epson i IBM) 
możliwe jest projektowanie własnych 
znaków i zapamiętanie ich przez dru- 

karkę. Niestety zmniejsza to szyb- 
kość współpracy z komputerem, po- 
nieważ pojemność pamięci drukarki 
wynosi tylko 4 KB (większość druka- 
rek posiada bufor 8 KB). 


Do sterowania pracą drukarki słu- 
żą przyciski znajdujące się na górnej 
pokrywie obudowy. Służą one do po- 
łączenia i odłączenia drukarki (ON 
LINE), przesunięcia o stronę (FORM 
FEED) i przesunięcia o wiersz (LINE 
FEED). Oprócz tego kombinowane 
użycie przycisków pozwala na wy- 
branie jednego z krojów pisma: Pica, 
NLQ, ltalics, Emphasized lub Redu- 
ced. Niestety wymaga to pewnej 
wprawy. Obok przycisków znajdują się 
diody sygnalizujące włączenie zasila- 
nia, gotowość do pracy i brak papieru. 

Włączenie drukarki z wciśniętymi 
przyciskami FF i LF wywołuje tryb 
ko piowania szesnastkowego. W od- 
różnieniu od poprzednio testowanych 
drukarek, oprócz kodów drukowane 
są także odpowiadające im znaki 
ASCII. Wciśnięcie przycisku LF przy 
włączaniu wywołuje, jak w innych 
urządzeniach, test drukarki — druko- 
wane są wszystkie znaki dostępne w 
wybranym trybie pracy. Dodatkowo po 
włączeniu z wciśniętymi przyciskami 


CITIZEN 120D 


Inne drukarki „Citizen” oferowane na 
nasz rynek przez firmę „Synelec” to: MSP- 
-10E, MSP-15E, MSP-40. MSP-45, MSP-50 
(kolor), MSP-55 (kolor), HOP-45 (24-igłowa), 
Premierę 35 (rozetkowa). 

W jednym z najbliższych numerów „Bajt- 
ka” zamieścimy test kolejnej drukarki CITI- 
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LF i ON LINE drukowany jest numer 


zastosowanego w drukarce układu 
ROM i EPROM z zestawem znaków. 

Do stałego ustawienia parametrów 
pracy drukarki służy zespół 10 prze- 
łączników umieszczonych na płytce z 
elektroniką. Dostępne są one po wy- 
sunięciu tej płytki lub przez niewielkie 
okienko obok prowadnicy głowicy dru- 
kującej. 


EKSPLOATACJA 


Podczas testowania badana była 
współpraca drukarki z komputera- 
mi Amstrad, Atari i Commodore. We 
wszystkich przypadkach drukarka 
pracowała bez zarzutu. Jakość wy- 
druków jest zbliżona do uzyskiwa- 
nych na poprzednio testowanej dru- 
karce DMP3160. Również tu w trybie 
graficznym pozostawał ślad przejścia 
głowicy. 

Użytkowanie drukarki jest proste i 
wygodne. Jedynie wybieranie krojów 
pisma przy pomocy przycisków wy- 
maga dokładności i dobrej pamięci 
(lub zajrzenia do instrukcji). Bardzo 
dogodna jest natomiast możliwość 
programowego przełączania trybów 
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Epson i IBM. Przy korzystaniu z pa- 
pieru w arkuszach daje się odczuć 
brak automatycznego podajnika — 
znajdujący się na wyposażeniu dru- 
karki służy jedynie do papieru z per- 
foracją. Z drugiej strony brak ostrej 
krawędzi ułatwiającej oderwanie pa- 
pieru z rolki. 

Kaseta zawiera dużą ilość taśmy 
drukującej, co zapewnia duży odstęp 
pomiędzy jej kolejnymi renowacjami. 
Dostęp do kasety i głowicy jest bardzo 
prosty i ich demontaż może wykonać 
każdy (oczywiście w przypadku głowi- 
cy należy korzystać z instrukcji). 

Praca drukarki jest stosunkowo 
cicha pomimo braku bezpośredniej 
osłony głowicy. Poziom hałasu jest 
zbliżony do wytwarzanego przez inne 
drukarki tej klasy. 
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CITIZEN 120D 


ON LINE 


PODSUMOWANIE 


Drukarka Citizen 120-D wyróżnia 
się w swojej klasie cenowej przede 
wszystkim znacznie większymi moż- 
liwościami wydruku tekstów. Więcej 
jest dostępnych odmian druku i ich 
kombinacji. Posiada ona także więcej 
znaków w trybie Epson oraz dodatko- 
wy, ósmy tryb graficzny. Duża żywot- 
ność taśmy predestynuje ją dla użyt- 
kowników wykonujących duże ilości 
wydruków jednorazowo. 
Zalety drukarki: 

— duża liczba zestawów znaków w try- 
bie Epson 

— dodatkowe znaki graficzne w trybie 
Epson 


TEST 


— duża liczba krojów pisma i ich kom- 
binacji 

— programowe przełączanie trybów 
Epson i IBM 

— możliwość justowania wydruku 

— dużo wariantów tabulacji i formato- 
wania wydruku 

— pełny wydruk 
szesnastkowym 


przy kopiowaniu 


Wady drukarki: 

— skomplikowany sposób wyboru 
krojów pisma przyciskami 

— brak krawędzi do odrywania części 
papieru z rolki 

— mała pojemność bufora 


Wojciech Zientara 


PARAMETRY TECHNICZNE DRUKARKI 
CITIZEN 120-D 
WG SPECYFIKACJI PRODUCENTA: 


głowica — 9-igłowa 


szybkość druku _ — 120 CPS w trybie 
draft, 24 CPS w trybie 
NLQ 


— 9 na 9 punktów 
(draft), 17 na 17 
punktów (NLQ) 


— 24 na 2.4 mm 


matryca znaków 


wielkość znaków 

gęstość druku — 20, 17, 15, 13, 3, 12, 
10, 8.5, 6 i 5 znaków 
na cal 

gęstość grafiki — 60, 72, 80, 90, 120, 
144 i 240 punktów 
na cal 


odstęp wierszy 


— 1/6,1/8, 7/72, n/72, 
n/144 lub n/216 cala 


— szerokość: 3—10 cali 
grubość: 0,06 
—0,3 mm 


papier 


trwałość taśmy  — 2 min znaków 


trwałość głowicy  — 10 min znaków 


interfejs — równoległy 
Centronics, 
8-bitowy (Amphenol) 

zasilanie — 180-264 V, 46-60 Hz, 
100 VA 

wymiary — długość 370 mm 
szerokość 238 mm 
wysokość 90 mm 


— 3,7 kg 
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Ostatnio poznaliśmy sposób, 
w jaki przechowywana jest w 
pamięci każda linia BASIC-a. 
oraz co oznaczają takie znaki 
kontrolne, jak CHR$ 14 i CHR$ 
8. W tym odcinku poznamy po- 
zostałe znaki kontrolne. Trzy z 
nich dotyczą zmiany miejsca 


wydruku, sześć — zmiany atry- 
butów.. 


Pierwszym z nich jest CHR$ 6 — „COMMA CON- 
TROL, czyli przecinek kontrolny. Ma on takie samo 
działanie, jak przecinek separujący teksty w instrukcji 
PRINT, tzn. drukuje tyle spacji (ale zawsze co najmniej 
jedną), by znaleźć się w kolumnie 0 lub 16: 

PRINT „t”, „2” 
oraz PRINT „1 „+ CHR$ 6+"2” 

mają identyczne znaczenie. 

Podobnie, znak CHR$ 22 — „AT CTRL czyli AT 
kontrolne, pozwala przenosić pozycję wydruku w do- 
wolne miejsce ekranu tak, jak AT w instrukcji PRINT. 
Po tym znaku muszą wystąpić dwa bajty, określające 
numer linii i numer kolumny, w której ma zostać umiesz- 
czony następny znak: 

PRINT AT 10,7;*"j 
est równoznaczne z 
PRINT CHR$ 22:CHRS 10;CHR$ 7;"!”. 
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Aby się przekonać, jak za pomocą tego znaku unie- 
możliwić prawidłowy listing programu, wpisz 
np.: 


10 RANDOMIZE LUSR 20000: 
dac! (6) 


REM ———Nic nie wi- 


— po instrukcji REM wpisz trzy spacje, a po wy- 
krzykniku — dwa przecinki kontrolne. Można je uzy- 
skać bezpośrednio z klawiatury, wciskając kolejno kla- 
wisze: EXTEND (lub dwa SHIFT-y na raz) by uzyskać 
kursor „E”, a następnie klawisz „6” (kursor zmieni kolor 
na żółty) i DELETE — kursor przeskoczy do najbliższej 
połówki ekranu. 

Po wpisaniu tej linii, wymieniamy te trzy spacje na 
znak AT 0,0 przez: 

POKE 23774,22;POKE 23775,0: POKE 23776,0. 

Spróbujmy teraz wylistować program. Na ekranie 
nie pojawia się tekst całej linii — początkowa jej część 
jest zakrywana przez napis znajdujący się za instruk- 
cją REM i znakiem AT CTRL. Podobne kłopoty są gdy 
ściągniemy tę linię do edycji (klawisz EDIT). 

Podane współrzędne w znaku AT CTRL powinny 
mieścić się na ekranie, tzn. numer linii nie może być 
większy niż 21, a numer kolumny — niż 31. Podanie 
większych wartości w przypadku PRINT lub LIST po- 
woduje komunikat „Out of screen” i zaprzestanie dal- 
szego drukowania. Jeśli zaś listing uzyskano przez wci- 
śnięcie ENTER (automatyczny listing) — także nastąpi 
zakończenie listowania programu, a ponadto na dole 
ekranu znajdzie się migający znak zapytania — sygnał 
błędu. Jest to więc praktyczny sposób na uniemożliwie- 
nie wylistowania każdego programu. 

Kolejnym znakiem kontrolnym jest CHR$23 — „TAB 
CTRL” — znak tabulacji poziomej. Po nim następują 
dwa bajty określające numer kolumny, do której ma zo- 
stać przeniesiona pozycja wydruku. Są one traktowane 
jako jedna, dwubajtowa liczba (pierwszy bajt mniej zna- 
czący). Ponieważ są jednak tylko 32 kolumny, to jest 
ona brana modulo 32, czyli jej starszy bajt i trzy najstar- 
sze bity młodszego bajtu są ignorowane. Drugą istotną 
Sprawą jest to, że TAB przenosi pozycję wydruku przez 
drukowanie spacji — podobnie jak przecinek kontrolny, 
może być więc użyty do zakrywania znajdujących się 
już na ekranie tekstów. 

Następną grupę znaków kontrolnych stanowią znaki 
zmieniające atrybuty. Są to: 


CHR$ 16 — INK CTRL 
CHR$ 17 — PAPER CTRL 
CHR$ 18 — FLASH CTRL 
CHR$ 19 — BRIGHT CTRL 
CHR$ 20 — INVERSE CTRL 
i CHR$ 21 — OVER CTRL. 


Po każdym z tych znaków konieczny jest jeden bajt, 
precyzujący o jaki atrybut chodzi. Po znakach INK i PA- 
PER mogą to być liczby 0 ... 9, po FLASH i BRIGHT: 
0,1 8, po INVERSEiOVER :0i1. Podanie innych war- 
tości wywołuje komunikat „Invalid colour” i oczywiście 
przerwanie listowania programu 

Odśmiecając program zabezpieczony znakami ko- 
lorów kontrolnych ustalamy sobie np., że jeśli przeglą- 
dając treść programu napotkamy kod znaku PAPER 
CTRL, to wpisujemy w jego drugim bajcie wartość 
0, jeśli INK CTRL — wartość 7, a w pozostałe znaki 
kontrolne kolorów — wartość 0. Poza tym usuwamy 
wszystkie przeszkadzające znaki BACKSPACE (CHR$ 
8) przez zastąpienie ich spacjami (CHR$ 32). Podobnie 
likwidujemy znaki AT CTRL — wymieniamy za pomocą 
POKE-ów trzy bajty znaku na spacje. Po takiej korekcie 
program daje się już wylistować bez żadnych niespo- 
dzianek. 

Jeśli chcesz się włamać do programu ładującego, 
nie musisz, a w zasadzie nie powinieneś go odśmiecać 
— ważne jest przecież to, aby dowiedzieć się co ten 
program robi, w jaki sposób ładuje do pamięci i uru- 
chamia następne bloki, a nie aby robił to „ładnie” i był 
napisany czysto i przejrzyście. Jest to ważne tym bar- 
dziej, że zanim nie poznasz dokładnie programu, lepiej 
nie rób w nim żadnych zmian — jedno zabezpieczenie 
może być sprawdzane przez inne. Dlatego najlepszym 
sposobem złamania programu jest analiza jego dzia- 
łania krok po kroku, odczytując kolejne bajty pamięci: 


0 BORDER 0: FAPER 0: INK Ó: CLS5 : PRINT 
fO,"LDADING";: FOR n=0 TO 20 STEF 4: BEEP 
„2,n: NEXT n: LDAD ""CODE : PRINT AT 19,05: 
LOAD ""CDDE : PRINT AT 197,0;: LOAD ""CODE : 


PRINT AT 19,03: LOAD ""CODE : PRINT AT 17,05 
LOAD ""CODE : RANDOMI ZE USR 24064 


Pamiętaj o właściwej interpretacji kolejnych bajtów: 
najpierw dwa bajty numeru linii, potem dwa bajty ozna- 
czające jej długość (które mogą być fałszywe), a na- 
stępnie tekst: instrukcja BASIC-a, potem jej parametry, 
za każdą liczbą CHR$ 14 i pięć bajtów zawierających 
wartość tej liczby. Za parametrami — dwukropek i na- 
stępna instrukcja lub ENTER i nowa linia programu. 

To by było na tyle, jeśli chodzi o znaki kontrolne. 
Jest jednak jeszcze jedna rzecz, którą trzeba wyjaśnić, 
abyś nie miał kłopotów z odczytywaniem BASIC-a. 
Chodzi o instrukcję DEF FN. Wpisz, a następnie obej- 
rzyj dokładnie taką linię: 

10 DEF FN a(a,b$,c)=a + c 

Wydaje się, że powinna ona zająć w pamięci 19 baj- 
tów (numer linii, jej długość, ENTER oraz 14 wpisanych 
znaków), ale tak nie jest. Interpreter po każdym para- 
metrze funkcji umieścił znak CHR$ 14 i zarezerwował 
na coś następne pięć bajtów. Na co? — zaraz się prze- 
konasz. Wpisz: 

PRINT FNa (1 ,”123”,2) 

i ponownie dokładnie obejrzyj zawartość pamięci 
od adresu 23755. Po pierwszym parametrze w delinicji 
funkcji dalej znajduje się CHR$ 14, ale po nim znalazły 
się kolejno: 0, 0, 1, 0, 0 co w pięciobajto wym zapi- 
sie oznacza liczbę 1. Podobnie, po trzecim parame- 
trze funkcji znajduje się CHR$ 14 i bajty oznaczające 
liczbę 2. Po parametrze b$ także znalazła się wartość 
użytego parametru: CHR$ 14 i pięć bajtów, które kolej- 
no oznaczają: pierwszy nie jest dla nas ważny, drugi i 
trzeci to adres, pod którym znajdował się łańcuch „123” 
(wywołanie funkcji nastąpiło w trybie bezpośrednim, 
więc adres ten dotyczy obszaru edycji linii BASIC-a), a 
bajty czwarty i piąty to długość łańcucha — w naszym 
przypadku wynosi ona 3 znaki. 

Pamiętaj o tym odczytując BASIC przez PEEK a nie 
LIST. Zdarza się czasem, że w tych właśnie bajtach za- 
rezerwowanych na rzeczywiste wartości funkcji ukryte 
są zabezpieczenia warunkujące działanie programu 
lub nawet program maszynowy ładujący następne bloki 
(np. Beta, Basic 1.0). 

Na zakończenie parę słów o programach ładują- 
cych — tzw. loaderach. Ich zadaniem jest wczytanie 
i uruchomienie wszystkich bloków składających się 
na program. Zazwyczaj robią to w sposób maksymal- 
nie utrudniający zrozumienie ich działania — tak, aby 
uruchomienie programu w inny sposób niż przez tego 
ładowacza (czyli w praktyce — włamanie się do niego) 
było niemożliwe. Robią to w mniej lub bardziej wyrafi- 
nowany sposób. Spójrzmy na ładowacze stosowane w 
większości produktów firmy ULTIMATE (np. Atic Atac, 
Knightlore, Pentagram, Night Shade itp.). Wyglądają 
one mniej więcej tak: 


FOR n=23755 TO PEEK 23627+256*PEEK 23628 
PRINT n;" ";PEEE n,CHR$ PEEK n AND PEEE nósi 
NEXT n 


Za takim ładowaczem znajduje się na taśmie pięć 
następnych bloków: ekran oraz zakodowany główny 
blok programu, a za nimi trzy króciutkie bloki zabezpie- 
czające program: jednobajtowy (kod instrukcji JP (HL) 
), kilkunastobajtowy (jest to procedura odkodowująca 
cały program), oraz ostatni — dwubajtowy, ładowany 
pod adres 23672, czyli do zmiennej FRAMES. Zawar- 
tość tej zmiennej jest zwiększona o 1 co 1/50 sekun- 
dy. W programie maszynowym uruchomionym przez 
RANDOMIZE USR 24064 wartość ta jest sprawdzana i 
jeśli jest inna, niż być powinna (co oznacza, że w mię- 
dzyczasie, już po załadowaniu, program był zatrzyma- 
ny na jakiś czas), następuje wyzerowanie komputera. 
Włamanie się do tego typu programów jest proste. Wy- 
starczy załadować wszystkie bloki za wyjątkiem ostat- 
niego, a po wylistowaniu programu, czy zrobieniu w 
nim odpowiednich zmian (np. wpisaniu POKE-ów unie- 
śmiertelniających grę) wystarczy tylko wpisać LOAD „” 
CODE: RANDOMIZE USR 24064 (ale koniecznie w 
jednej linii, rozdzielając instrukcje dwukropkiem), by 
uruchomić grę. 

Oddzielną sprawa jest odkodowanie programu, czyli 
uruchomienie procedurki odkodowującej w taki sposób, 
by po zakończeniu działania wróciła do BASIC-a. Czy- 
telnikom znającym asembler nie powinno to sprawić 
kłopotu, jednak ze względu na powszechność stoso- 
wania tego typu zabezpieczeń, szczególnie w progra- 
mach użytkowych (np. Art Studio czy The Last Word), 
wrócimy jescze do tego tematu. 

A za miesiąc zakończymy sprawę programów ładu- 
jących, tzn. ich BASIC-owej części i już na dobre zaj- 
miemy się asemblerem. 


Tomasz Surmacz 
Robert Dudzik 
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Chcąc zapewnić sobie możliwość dłu- 
gotrwałego użytkowania ZX SPECTRUM, 
musimy stale pamiętać o tym, aby oprócz 
przestrzegania podstawowych wytycznych 
instrukcji obsługi dbać o stan klawiatury. 


Mechaniczne wycieranie się folii i uszkodzenia ście- 
żek przewodzących znajdujących się pod klawiszami 
wymienia się jako jedną z głównych wad, która niestety 
nie została całkowicie usunięta w nowszych wersjach 
tego komputera. Szczególnie duże niebezpieczeństwo 
przedwczesnego wyeksploatowania klawiatury wiąże 
się z wykorzystaniem mikrokomputera do gier, w któ- 
rych zazwyczaj będziemy używali wybiórczo tylko kilku 
z klawiszy. Angażując się emocjonalnie w dramaturgię 
gry i nieraz błyskawicznie następujące po sobie wyda- 
rzenia, wcześniej czy później zapomnimy o delikatnym 
naciskaniu klawiszy. 

Czy miałoby to oznaczać, że z naszych zbiorów gier 
powinniśmy usunąć te, które są dostosowane tylko do 
sterowania z klawiatury? 

Wręcz przeciwnie! Uważam, iż wiele z nich może 
pod względem swych walorów śmiało konkurować z 
przebojami ostatnich lat. Do niektórych z nich chęt- 
nie powracamy, chociaż nowsze gry z reguły są lepiej 
opracowane graficznie, dźwiękowo etc. Obserwując 
publikowane lawinowo przez POKE-rzystów rozmaite 
ułatwienia w postaci "wiecznego życia", "niezmiennej 
energii" lub "wstrzymania upływu czasu", chcę zapro- 
ponować wprowadzenie do programów gier niewielkich 
zmian, dzięki którym będziemy mogli przenieść funkcję 
sterowania "z klawiatury na joystick". 

Czytelnikowi, pragnącemu skorzystać z moich 
uwag, potrzebne będą dwa "programy narzędziowe": 
powszechnie używany program COPY-COPY opraco- 
wany przez T. Wilczka oraz program MONS 3M i GENS 
3M firmy HISOFT. 

Stan poszczególnych portów odczytuje instrukcja 
Basica IN W. Adres W, będący liczbą z przedziału 
<0;65535>, odpowiada różnym urządzeniom wejścia. 
Zmiany stanu portów można badać za pomocą progra- 
mu: 

10 INPUT "Adres portu - ";W 

20 PRINT IN W; ""; 

30 GOTO 20 

Standardowo używa się tylko wybranych adresów, 
co znacznie ułatwi nam analizę gier. Oto zestawienie 
adresów standardowych portów: 


Adres portu klawiatury 


Obsługuje 
rząd klawiszy 


ENTER — H 
SPACE — B 

Wprowadzając do podanego wyżej programu te 
adresy zauważymy, że gdy nie naciskamy żadnego z 
klawiszy w danym rzędzie, to wczytywany będzie bajt o 
wartości 191 (binarnie 10111111)”. Po naciśnięciu jakie- 
goś klawisza tego rzędu nastąpi wygaszenie odpowia- 
dającego mu bitu (pozycja bitu wzrasta w kierunku do 
wnętrza rzędu). Na przykład, po wprowadzeniu instruk- 
cji PRINT IN 65022 oraz naciśnięciu klawisza F nastąpi 
zgaszenie bitu 3 i odczytany bajt będzie miał wartość 
187, a po równoczesnym naciśnięciu klawiszy A i G zo- 
staną zgaszone bity 0 i 4, wskutek czego odczytana 
wartość bajtu będzie równa 174. 

Podobnie, wykorzystując ten sam program, może- 
my sprawdzić wartość bajtu odczytywanego z portu joy- 
sticka. W przypadku używanego najczęściej joysticka 
typu KEMPSTON, instrukcja IN 21 odczytuje wartość 0 
gdy drążek znajduje się w martwym jego położeniu lub 
naciśnięciu FIRE, zostanie zapalony odpowiedni bit, a 
więc "w prawo" — bit O, "w lewo" — bit 1, itd. Skutkiem 
tego będzie odczytanie z portu joysticka wartości 1, 2, 
itd, 

Teraz poprawienie programów napisanych w języku 
Basic nie powinno sprawiać żadnych trudności Odszu- 
kujemy linie z instrukcjami odczytującymi stan klawia- 
tury, np.: 

230 IF INKEY$ = "c" THEN GOTO 270 

Chcąc osiągnąć ten sam efekt po wychyleniu drąż- 
ka joysticka "w przód", zmieniamy zapis na: 

230 IF IN 21 =8 THEN GOTO 270 

albo pozostawiając bez zmian instrukcję czytania 
klawiatury dodajemy: 

230 IF INKEY$ ="c" ORIN21 =8 THEN GOTO 270 

Niestety, ciekawe gry są stosunkowo rzadko pisane 
w Basicu (np. MINED OUT). Znaczna ich większość 


ma procedury w kodzie maszynowym, w którym osią- 
ga się dużo większą dynamikę gry i bardziej atrakcyjne 
rozwiązania graficzne. 

Dlatego, zanim przystąpimy do omawiania konkret- 
nego podprogramu przejścia "z klawiatury na joystick", 
musimy jeszcze pokrótce przedstawić sposoby odczy- 
tywania stanu klawiatury bezpośrednio z poziomu kodu 
maszynowego. 

Najczęściej będą to rozkazy mikroprocesora Z80, 
odczytujące stan klawiatury poprzez standardowe por- 
ty: 


Odpowiednikiem instrukcji Basica: 
1) LET W = IN 65022 może być: 
LDA, 4FD LD BC, £ FDFE 
lub 

IN A,(4FE) LN A, (CG) 


(wartość odczytanego bajtu będzie w akumulatorze) 
2) LETW=IN21 może byc: 


XOR A LD BC,££0015 
lub 
IN A,( 15 NB, (0) 


(W w akumulatorze) (W w rejestrze B) 

Innym sposobem będzie wykorzystanie zmiennych 
systemowych. które przechowują kody ASCII, odpowia- 
dające danemu klawiszowi. I tak, pod adresem 23556 
(45004) znajdziemy za pomocą funkcji PEEK kod aktu- 
alnie naciskanego klawisza w trybie C. W podobny spo- 
sób możemy znaleźć kod ostatnio naciśniętego klawi- 
sza, przechowywany w zmiennej systemowej LAST K 
o adresie 23560 (+: 5008) Normalnie są to kody klawi- 
szy w trybie L, lecz równoczesne naciśnięcie któregoś 
z SHIFT'ów spowoduje odpowiednią zmianę wartości 
kodu w zmiennei LAST K. 

Proszę zauważyć, że standardowo para rejestrów 
IY zawiera adres bazowy obszaru zmiennych systemo- 
wych, równy 23610 (+ 5C3A). Dzięki temu wartość kodu 
z ze zmiennej LAST K możemy zakładać do akumula- 
tora za pomocą rozkazu LD A, (23560), albo w trybie 
adresowania indeksowego LD A, (IY-50). 

Kolejnym ze sposobów może być wywołanie pod- 
programu KEYSCAN z pamięci ROM, rozpoczynające- 
go się od adresu 654 (+: 028E). Ładuje on kod naciśnię- 
tego klawisza do pary rejestrów DE, przy czym rejestr 
D będzie zawierał liczbę z przedziału <0;39>, a rejestr 
E liczbę wskazującą z jakim SHIFT'em klawisz został 
naciśnięty. Przy równoczesnym naciśnięciu kilku klawi- 
szy znacznik zera będzie zgaszony. Natomiast, gdy nie 
naciśnięto żadnego z klawiszy, w parze rejestrów DE 
będzie wartość 4£FEFE, a znacznik zera będzie zapa- 
lony. Dla zbadania wartości w rejestrach D i E oraz sta- 
nu znacznika zera można skorzystać z następującego 
programu: 

20 LETs=0 : For i=:OTO 18: READa: POKE 30003 
+1,a: 

LET s=s+a: NEXT i: IF S<>1447 THEN PRINT "PO- 
PRAW Dane": STOP 30 PRINT: PRINT INKEY$ 

40 RANDOMIZE USR 30003 

50 PRINT "D ="; PEEK 30001; '"E ="; PEEK 30000 

60 PRINT "Znacznik zera = "; PEEK 30002 

70 PAUSE 100: POKE 23692,5: GOTO 30 

80 DATA 205, 142,2, 237, 83, 48, 117, 40,4 

90 DATA 62,0, 24,2, 61,1, 50, 50, 117, 201 

Program wywołuje procedurę KEY-SCAN z pamięci 
ROM i wpisuje wartości rejestrów D i E oraz znacznika 
zera do komórek 30000 30002 (są one różne od war- 
tości wg kodu ASCII). 

Należy na koniec zauważyć, że są to najczęściej 
wykorzystywane procedury odczytu stanu klawiatury w 
języku maszynowym. Wyszukanie w tekście programu 
w kodzie maszynowym odpowiedniego fragmentu "czy- 


tającego klawiaturę" i analiza jego działania jest niewąt- 

pliwie najtrudniejszym etapem pracy. 

Proponuję następujący algorytm postępowania. 

1) Ustalić adresy startowe i długości poszczególnych 
bloków programu (przy pomocy programu ładujące- 
go grę albo programu COPY-COPY). 

2) Zapoznać się z działaniem poszczególnych klawiszy, 
jakich używamy podczas gry. Zdecydować, które z 
działań będziemy symulować za pomocą joysticka 
(ruchem drążka, naciśnięciem FIRE, ewentualnie 
równoczesnym wykonaniem obu tych czynności). 

3) Sprawdzić, czy bloki programu, realizujące daną grę, 
nie uruchamiają się automatycznie. Jeżeli bloki były- 
by zbyt długie można je dzielić za pomocą programu 
COPY- COPY. 

4) Wgrać blok programu, a w wolny obszar pamięci 
RAM program MONS 3M. Uruchomić program moni- 
torujący i ustawić licznik główny programu na począ- 
tek badanego bloku. 

5) Rozkazem G wyszukać sekwencje rozkazów od- 
czytujących stan klawiatury, wpisując na przykład: 
G:DB:FE G:ED: 78 G:8:5C itp. oraz zapisać 
adresy tych rozkazów. 

6) Ustawić licznik główny programu na pierwszy ze 
znalezionych adresów. Jeżeli trzeba, cofnąć licznik 
główny o kilka komórek w celu odczytania starsze- 
go bajtu adresu portu i rejestru do jakiego będzie on 
załadowany, nie zmieniając przy tym desasemblacji 
programu. Wyświetlić stronę disasemblacji i szcze- 
gółowo przeanalizować działanie programu odczytu- 
jącego stan klawiatury. 

7) Przeszukać, jeżeli trzeba, pozostałe bloki programu 
gry w sposób podany w pp. 4 /+1 6. 

8) Wybrać wolny obszar w pamięci RAM i ułożyć pod- 
program obsługi joysticka, nie eliminujący oryginal- 
nej procedury sterowania z klawiatury, według na- 
stępującego schematu (np. funkcję klawisza (KL) 
symulujemy ruchem drążka "w prawo"): 


ORGNN _ podprogram zaczyna się od adresu NN 

XOR A wczytuje do akumulatora 

IN A,(15) wartość z portu joysticka 

Bi: BITO,A sprawdza, czy drążek wychylony "w prawo" 
(czy bit O równy jedynce) 

JR Z,B2 skok do kolejnego modułu, gdy warunek nie 
spełniony (bit O równy zero) 

LD A,d ładuje do akumulatora wartość kodu d, jaka 
byłaby odczytana według procedury w pro- 
gramie głównym po naciśnięciu klawisza KL 

RET powrót do programu głównego i wykonania 
podprogramu obsługi klawisza KL 

B2: BIT 1A czy drążek wychylony "w lewo" — początek 
modułu symulacji następnego klawisza 

C: linie programu głównego, odczytujące stan 
klawiatur, zastąpione w nim przez CALL NN 

RET powrót do programu głównego 


Przy układaniu tego podprogramu wygodne będzie 
użycie programu GENS 3M, za pomocą którego wyge- 
nerowany kod wynikowy wygrywamy na taśmę. 

9) Zastąpić w analizowanym bloku wszystkie rozkazy 
odczytujące stan danego klawisza rozkazem wywo- 
łania podprogramu obsługi joysticka CALL NN (stan 
tego samego klawisza może być oJczytywany w kil- 
ku różnych miejscach programu). Poprawiony blok 
nagrać na taśmę. 

10) Wmontować opracowany podprogram obsługi joy- 
sticka do poprawionego programu gry za pomocą 
programu COPY-COPY, albo z poziomu języka Ba- 
sic za pomocą instrukcji POKE (pamiętając o tym, 
aby nie kolidował on z obszarem programu główne- 
go, a także aby został wczytany do pamięci RAM 
przed uruchomieniem się gry). 

11) Sprawdzić poprawność działania poprawionego 
programu. 

Za miesiąc podam sposoby przystosowania kilku 
popularnych gier do sterowania joystickiem. 


Adam Gawłowski 


*) albo 31 (binarnie 00011111) w przypadku mikro- 
komputera TIMEX 2048 

**) w przypadku mikrokomputera TIMEX 2048 będą to 
wartości 23 i 14 odpowiednio 

***) dla joysticka innego typu adresy portów i wartości 
odczytanego bajtu będą inne, co należy ustalić 
przed przystąpieniem do przeróbek 
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NIE TYLKO 
DLA NERWOWYCH 


GRACZY 


Teoretycznie mogłoby się wydawać, 
iż drążek jest elementem wytrzymałym 
na wszystko i tak prostym, że w żaden 
sposób nie może zaszkodzić kompute- 
rowi. Jak mylny jest to pogląd wiedzą 
chyba wszyscy użytkownicy, którzy 
zmuszeni byli do wymiany jednego z 
układów scalonych komputera i to by- 
najmniej wcale nie najtańszego... 


We wszystkich komputerach Commodore drążki 
sterowe są obsługiwane przez specjalizowane ukła- 
dy interfejsowe: w C-64 i 128 są to układy 6526 CIA 
(Complex Intreface Adapter), w VIC-20 układ VIA 
(6522), w rodzinie C-16/116 i PLUS/4 (układ 7360 
(TED) wraz z układem 6529B. Zupełnie nie wiadomo 
dlaczego przyjęło się, że nie wolno odłączać podczas 
pracy komputera jakichkolwiek urządzeń peryferyj- 
nych z wyjątkiem drążków. W efekcie delikatne struk- 
tury układów nie wytrzymują iskrzeń obecnych przy 
wkładaniu wtyku drążka do innego portu czy palą się 
pod wpływem ładunków elektrostatycznych. 

Najczęstszym objawem uszkodzenia takiego ukła- 
du jest nagły brak kontaktu np. przycisku FIRE czy 
niemożność przesunięcia sterowanego obiektu w 
jakąś stronę. Jeżeli więc po przetestowaniu drążka 
stwierdzimy, że jest on całkowicie sprawny oznacza 
to, że spaleniu uległa sekcja układu scalonego i trze- 
ba go będzie wymienić. Niech się nikomu nie wydaje, 
ze jest to wyjątkowo proste: sam układ kosztuje za 
granicą ok. 15 dolarów i jest raczej trudnodostępny 
(własna produkcja Commodore). W Polsce sam układ 
CIA kosztuje w chwili gdy to piszę ok. 50 000 zł (bez 
naprawy) i konia z rzędem temu, kto go dostanie przy 
pierwszym podejściu (nawet na giełdzie). 

Jak z tego widać warto dbać również o tak prymi- 
tywny element jak drążek. Jeżeli będziesz stosował 
się do poniżej podanych zasad nie powinieneś mieć z 
drążkiem żadnych problemów. Warto o tym pamiętać 
ponieważ przydaje się on nie tylko do gier ale wyko- 
rzystują go też znacznie ciekawsze programy takie 
jak GEOS, NEWSROOM, CERTIFICATE MAKER, PRINT 
MASTER PLUS i wiele innych. 

1. NIGDY nie przełączaj (przyłączaj) drążka w 
czasie gdy komputer jest włączony. Najprostszym 
rozwiązaniem jest zakup drugiego drążka i przyłącze- 
nie obu na stałe do komputera; ich przełączenie nie 
będzie wtedy konieczne. 

2. Przelewanie emocji grającego na styki joystic- 
ka skraca jego życie o co najmniej połowę styki są 
oczywiście niedostępne). Jeżeli nie jesteś w stanie 
się opanować, spróbuj nabyć drążek pracujący w 
oparciu o mikrowyłączniki (są już takie drążki ro- 
dzimej produkcji w cenie ok. 5000 — 6000 zł. 

3. Staraj się zawsze tak ustawiać komputer, 
aby uniemożliwić przypadkowe dotknięcie ręką 
do portów obu drążków (dotyczy to także wszyst- 
kich innych gniazd). 

4. Nie używaj drążków uszkodzonych czy nie- 
pewnych, nie szarp też za przewód połączenio- 
wy. Jeśli Twój drążek ma gumowe przysawki i chcesz 
go przesunąć, unoś go zawsze za obudowę, a nigdy 
za rączkę. 

5. Przy przenoszeniu joysticka nie owijaj przewo- 
du dookoło rączki, gdyż może to spowodować we- 
wnętrzne pęknięcie jednej z jego żył. 

6. Jeżeli Twój drążek jest wyposażony w przycisk 
AUTOFIRE, to sprawdzaj każdorazowo przed włą- 
czeniem komputera, czy jest on wyłączony. Ruchy 
drążkiem przyłączonym do portu są odbierane przez 
układ CIA i jak normalnie wciśnięte klawisza, tak więc 
poruszenie rączką może spowodować ukazanie się 
na ekranie dziwnych znaków, liter, cyfr itp. 


Klaudiusz Dybowski 
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PRZEDSTAWIAMY WARSAW BASIC (3) 


ORGANIZACJA PAWIĘCI 


Za konfiguracje amięci 
komputera C-64. wykorzy- 
stywana rzez _ interpreter 
CHM V2.0, odpowiedzialne sa 


zmienne systemowe, któryc 
wartości Rrzeć owywane sa 
od $0000 do $0333 I o 000 
do $dfff. 


O tym jaka część pamięci przeznaczona jest na tekst 
programu, zmienne, tablice i wartości wyrażeń teksto- 
wych decydują zmienne systemowe: $2b/$2c — począ- 
tek programu (TXTTAB), $2d/$2e — początek zmiennych 
(VARTAB), $2f/$30 — początek tablic (ARY TAB), $31/$32 
— koniec tablic (STREND). — $33/$34 — koniec warto- 
ści wyrażeń tekstowych (FRETOP) i $37/$38 — początek 
wartości wyrażeń tekstowych i koniec dostępnej pamięci 
(MEMTOP). 

Po inicjacji interpretera CBM V2.0, dla programu do- 


w pakiety, nakładkowania itp. Dzieje się to wszystko w 
sposób niewidoczny dla użytkownika. 

Przy pracy z procedurami można wyróżnić kilka po- 
ziomów pamięci. Na poziomie 0 jest program główny, 
wczytywany dynamicznie w trybie bezpośrednim i jego 
zmienne, zakładane w trybie programowym. Procedury 
wywoływane przez program główny, wczytywane dyna- 
micznie w trybie programowym i ich zmienne (lokalne) 
zajmują poziom 1. Początek nowego poziomu znajduje 
się bezpośrednio za końcem tablic poziomu poprzednie- 
go. Aby w każdej chwili można było rozpoznać aktualną 
konfigurację pamięci na danym poziomie, w Warsaw BA- 
SIC-u wprowadzono instrukcję MEM(ory) (patrz BAJTEK 
7/87). Na użytek czytelników naszego cyklu podajemy 
uproszczoną wersję tej instrukcji, wywoływaną przez £m. 
Program 2 umożliwia, po dołączeniu do programu z po- 
przedniego odcinka i wykonaniu tej instrukcji, odczytanie 
liczby wolnych bajtów na poziomie 0. 

Program organizujący inne poziomy przedstawimy w 
jednym z następnych odcinków. Wtedy instrukcja £m bę- 
dzie również pomocna w czasie "ręcznej" wędrówki po 
różnych poziomach 


stępna jest pamięć rozpoczynająca się od adresu $0800, | 
pod którym jest wstawiona wartość $00. Zmienna TXT- ; Krzy sztof Gaj ewsk 
TAB wskazuje na adres $0801, który jest właściwym po- L Bog usław Radziszewski 
czątkiem programu. Linie programu są zapisywane od 
tego adresu w formacie: wskaźnik do początku następnej l 
linii (2 bajty), numer linii (2 bajty), treść linii (nie więcej $ URG 40475 
niż 79 znaków) i koniec linii (1 bajt $00). Interpreter roz- 4 TYTAB = Ż0QTB 
poznaje koniec linii programu po napotkaniu zerowego 4 LDY HEDĄ 
wskaźnika (500 $00) do początku następnej linii. W stan- 5 LDA HZ 
dardowym interpreterze następny adres po tym wskaź- b JSR HABIE 
niku przechowuje zmienna VARTAB Koniec zmiennych ) 
pokrywa się z początkiem tablic (ARYTAB). Deklaracja 7 LDX 1406 
lub zakładanie nowych zmiennych powoduje przesu- 8 LDY HEROD 
wanie się w kierunku wyższych adresów końca tablic 7 LDA TATAB,Y 
(STREND). W chwili uruchomienia programu MEMTOP | 10 SEC 
pokrywa się z FRETOP. W miarę orzybywania wyników Li SBL $ZB, A 
działań na tekstach zawartość FRETOP przesuwa się w 2 STA ŻFE 
kierunku niższych adresów. Ki LDA TXTAB+1,Y 
Jak wiemy, jeżeli założenie nowej zmiennej spowo- 14 BBC PL. X 
dowałoby przekroczenie FRETOP brzez STREND, to sy- i5 LDX FE 
gnalizowany jest błąd OUT OF MEMORY (brak pamięci). 16 STY £DZ 
Nie wszyscy jednak wiedzą, że obniżenie FRETOP poni- 17 JSR HEDCD 
żej STREND (próba zapisania nowej wartości wyrażenia ; 
tekstowego) nie jest sygnalizowane. W tym przypadku in- 18 LDA HFC 
terpreter przesuwa FRETOP do pozycji wyjściowej (traci 17 LDY FŚCĄ 
się dostęp do wcześniej wypracowanych tekstów). 20 J5R  HABIE 
Interpreter CBM V2.0 toleruje również inne usytuowa- | £ LDA  HCĄCA 
nie względem siebie swoich danych (programu i zmien- Paa ORA ERO) 
nych). Początek tekstu programu można umieszczać w 28 JHE CHROUT 
dowolnym, dostępnym miejscu w pamięci. Koniec pro- 2 HEX PZAGAOBOBOADADADADIE 
gramu nie musi pokrywać się z początkiem zmiennych DE HEX ZOBOCYAEFAAFEDEOEDĄE 
(VARTAB). Co więcej, tekst programu może być umiesz- G HEX OAASEPAOZOPEZOWROZARO 
czony za zmiennymi nawet powyżej adresu wskazywane- WOJE 
go przez MEMTOP. 2 HEX 0D0D374F4C4E453A0000 
W Warsaw BASIC-u te różne konfiguracje są wyko- | > HEX 0D504F5A474F 4DSARO0O 
rzystywane np. do organizowania bloku zmiennych lo- 27 HABIE SW ŻABIE 
kalnych, wspólnego bloku zmiennych, RAM dysku, para- | 50 HBDCD = $BDCD 
metrów formalnych, przekazywania wartości parametrów | 31 HCĄLA = 4C4CA 
przez wartość lub nazwę, wywoływania procedur, ich | żż CHROUT  %£FFD2 
zagnieżdżania, automatycznego zestawiania procedur 
20CM FRINT' CZESC 2 U 
2037 ABSOL LZEN=POECEO 
210 FORIEOTON:READASFOREX+I,A:CEC+ASNEXT 
zlo IFPCEHIOSZOTHENFRINT" CZESC 2 Ok ":GBOTOZZS 
za FRINT" BLRGD W CZESCI 2 " s: END 
zem FPORESDOŻÓOD, /*lórA:FPORKESOŻ5G6G,10*16+4 
230 DATA160,176,169,167,52,50,171,162,6,160,8,185 
zas DATAAĄŻ,0,B65, 245, 45,133,254,185,44,0, 245,44 
240 DATA166,254,152,211,52,205,189,169,207,160,196,32 
245 DATAZ0,171,175,202,196,9,48,76,210,255,147,160 
250 DATA160,160,160,160,160,160,160,18,42,160,201,78 
255 DATAB4,69,82,80,82,69,84,67,82,160,48,46 
260 DATA48,160,42,160,15,15,87,79,76,78,69,58 
265 DATA0,0,13,80,79,90,73,79,77,58,160,0 


Wspominałem już, że prze- 
kładanie drążka z portu do 
portu nie jest ani bezpieczne 
dla komputera ani też nie przy- 
czynia się do przedłużenia ży- 
wotności układów scalonych 
obsługujących drążki. Jako 
dowód przedstawiam czytel- 
nikom schematy obrazujące 
sposób przyłączenia obu por- 
tów do poszczególnych ukła- 
dów scalonych w C- 128, C-64 
i C-16/116/PLUS/4. 


Schematy te mogą służyć także 
do jeszcze innego celu. Jak wiadomo 
na rynku są powszechnie dostępne 
drążki z wtykiem dziewięciobolcowym 
czyli do C-64, C-128, Atari, nie ma 
natomiast drążków do rodziny kom- 
puterów C-16. Na rysunku 4 przed- 
stawiono wyprowadzenia obu portów 
w C-16/116/PLUS/4 oraz C-64/C-128. 
Kontakt powoduje zwarcie jednej z li- 
nii JOYA0-JOYA3 lub JOYBO0-JOYB3 
z masą układu dostępną na nóżce 8 
w C-64/128 WB z nóżką 8 (w C-16, 
116, PLUS/4). Jeżeli więc ktoś ma 
smykałkę w ręku wykona we własnym 
zakresie odpowiednią wtyczkę (lub 
nabędzie takową na giełdzie) i będzie 
w stanie przerobić zwykły drążek w 
drążek do C-16. Poszczególne linie 
oznaczają: Nóżka 1 gniazda — JOY- 
AO (JOYBO) — góra dla C-64-128, 
dół, dla rodziny C-16 Nóżka 2 gniazda 
— JOYA1 (JOYB1) — dół, dla C-64/ 
R8, góra dla rodziny C-16. Nóżka 3 
gniazda — JOYA2 (JOYB2) — lewo, 


Nóżka 4 gniazda — JOYA3 (JOYB3) 
— prawo, 

Nóżka 5 gniazda— nie dotyczy drąż- 
ka w 0-64/128, 

Nóżka 5 gniazda — +5V w C-16/116/ 
PLUS/, 

Nóżka 6 gniazda — BTNA (BTNB) — 
FIRE, 

Nóżka 7 gniazda — masa w C-16/116/ 
PLUS/, 

Nóżka 7 gniazda — +5V w C-64/128, 
korzysta też z tego AUTOFIRE, Nóż- 
ka 8 gniazda — masa w C-64/128, 
Nóżka 8 gniazda — linia sygnałowa 
C- 16/116/PLUS/4 

Nóżka 9 gniazda — nie dotyczy drąż- 
ka w C-64/128. 

Jeżeli wśród czytelników są 
tacy, którzy początkują dopiero jako 
elektronicy- amatorzy lub woleliby 
prostsze rozwiązanie to informuję, 
że czasami można dostać na gieł- 
dzie odpowiednie wtyki przejściowe 
umożliwiające przyłączenie drążków 
standardowych do rodziny kompute- 
rów C-16. Nowicjuszom polecałbym 
asystę fachowców podczas zmiany 
wtyków drążka. 

Ze schematów można także od- 
czytać, iż najbardziej podatnym na 
uszkodzenia układu obsługującego 
drążek jest Commodore 64 — gniaz- 
do tego portu jest połączone BEZPO- 
SREDNIO z układem bez żadnych 
buforów jak ma to miejsce w C-128 
czy rodzinie C-16. Zwracam więc 
jeszcze raz uwagę użytkowników, aby 
nie przełączać drążków gdy komputer 
jest włączony. 


Klaudiusz Dybowski 


Rys. 1. Połączenie portów drążków z układem CIA —- Commodore 128. Strzałki wskazują 
połączenie linii ze złączem klawiatury. 


ELEKTRONIKA JOYSTICKA 


Rys. 2. Połączenie portów drążków z układem CIA — Commodore 64. Strzałki wskazują 
połączenie linii ze złączem klawiatury. Wartości cewek nieznane. Wartości kondensato- 
rów CA0-CA3 i CBO0-CB3 = 100 pikofaradów, C71 — 0,1 mikrofarada. 


CR 


14 
joyJA1 16 4 


|JOYJ A3 


|IJOYJ A4 


DO UKŁADU U102 (C116) 
LUB U4 (PLUS/4) 


Ro Ri R2 Ra R4 


U 


JOYB2 IKE 
JOYB3 |) 


JOYB4 


DO UKŁADU U102 (C116) 
LUB U4 (PLUS/4) 


Rys. 3. Połączenie portów drąż- 
ków z układem TED — rodzina 
C-16. Strzałki wskazują połącze- 
nie linii ze złączem klawiatury. 
Wartości cewek nieznane. Dio- 
dy CR — 1N914B. Wartości rezy- 
storów — 3,3 kiloomów. 


Rys. 4. Gniazda portów drążków sterowych a) C-64/128 b) C-16/116/PLUS/4. 
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OYTEST 


Zabawa w gry komputerowe bywa 
czasami bardzo kosztowna wystar- 
czy tylko jedno przełączenie drążka z 
portu do portu w czasie gdy kompu- 
ter jest włączony... Znacznie częściej 
jednak usterce ulegają styki drążka, 
pękają membranki czy blaszki sprę- 
żynujące. 


Jak sprawdzić co uległo uszkodzeniu — kom- 
puter czy drążek? Bardzo prosto. Wystarczy w 
tym celu wpisać i uruchomić jeden z podanych 
poniżej programów, w zależności od posiadane- 
go komputera. Można oczywiście zrobić to tak- 
że wczytując pierwszą lepszą grę, pewniejsze 
są jednak podane tu programy. Oprócz samej 
animacji ruchu drążkiem na ekranie użytkownik 
otrzymuje także informację o sygnale wejścio- 
wym generowanym przez drążek. Dzięki temu 
możemy np. określić, czy styki są czyste i kontak- 
tują za każdym razem, czy AUTOFIRE generuje 
regularny sygnał itp. 

Przed uruchomieniem programu warto go bę- 
dzie zapisać na taśmie czy dysku, należy też pa- 
miętać o tym, aby drążek był podłączony PRZED 
włączeniem komputera. Przeprowadzenie testu 
jest możliwe zarówno z portu 1 jak i 2, bez róż- 
nicy. 


Klaudiusz Dybowski 


100 REM **+ JOYTEST 16/116/PLUS/4 *kx 
105 : 

110 REM *x+ K. DYBOWSKI +kk 

115 : 

120 : 

125 SCNCLR: GRAPHIC CLR: CHAR 
1,9,12,"PORT 1 CZU 2 (1/2) : ":INPUT P 
130 IF P<i OR P>2 GOTO 125 

135 P$="FUNKCJA 

JOY ("+RIGHT$ (STR$(P) ,1)+ ") = 
":E$=CHR$ (209) 

140 COLOR i,1:COLOR 0,2:GRAPHIC 1,1 
145 : 

150 FOR I=i TO 4:READ K,L,M,N:BOX 
1,K,L,M,N: NEXT 

155 FOR I=0 TO 135 STEP 45:BOX 
1,128,95,198,105,1,1:NEXT 

160 BOX 1,230,50,240,170,,1:BOX 
1,113,165,240,175,,1:CIRCLE 
1,204,52,8,8 

165 : 

170 A=JOY(P):W=O:CHAR 1,X,Y," ":CHAR 
1,25,6," ":X=20:Y=12 

175 IF A=Q THEN CHARI ,20,12,E$:GOTO 
230 

180 IF A=>128 THEN W=128:A=(A AND 
127):CHAR 1,25,6,E$ 

185 IF A=1 THEN 
190 IF A=2 THEN 
195 IF A=Z THEN 
200 IF A=4 THEN 
205 IF A=5 THEN 
210 IF A=4 THEN 
215 IF A=7 THEN 
220 IF A=B THEN 
225 : 

230 A$=STR$ (A+) : IFLEN(A$) =4THENA$=RIG 
HT$ (A$ 5) :ELSE: A$="00"+RIGHT$ (A$, 1) 
235 CHAR 1,10,1,P$+A$,1:CHAR 1,X,Y,E$ 
240 GOTO 170 

245 : 

250 DATA 
097,038,226,162,100,040,223,160 

255 DATA 
103,042,220,158,094,036,229,164 


Pę p4 4 > > p Z 
UKGLELELELSE 


12  BAJTEK 4/88 


http://www.t2e.pl/reduksy 


100 REM *k* _ JOYTEST 128 
105 : 
110 REM ***k  K. DYBOWSKI 
115: 
120 : 


125 5CNCLR: GRAPHIC CLR: CHAR 
1,7,12,"PORT 1 CZY 2 (1/2) : ":INPUT P 


130 IF P<1 OR P>ź GOTO 125 


135 P$="FUNKCJA 
JDY ("+RIGHT$ (STR$(P) ,1)+") = ":GDSUB 
260 


140 COLOR 1,1:CDLOR 0,2:GRAPHIC 1,1 
145 X1=160:Y1=130: X2=197: Y2=90: XJ=125 
:Y3=168 

150 : 


155 FOR X=1 TO 4:READ K,L,M,N:BOX 
1,K,L,M,N:NEXT:BOX 1,150,145,170,153,1 


160 FOR X=0 TO 135 STEP 45:BOX 
1,125,95,195,105,X,1: NEXT 


165 MOVSPR 1,X1,Y1:MOVSPR 2,Xi,Y1 


170 BOX 1,227,50,237,170,,1:BOX 
1,107,165,237,175,,1 

175 : 

180 A=JOY (P) :W=0: SPRITE 
1,1,8,0,1,1:SPRITE 2,1,8,0,1,1 

185 IF A=0 OR A=128 THEN MOVSPR 
1,X1,Y1:MOVSPR 2,X1,YL 

190 IF A=>128 THEN W=128: SPRITE 
2,1,3,0,1,1:A=(A AND 127) 

195 IF A=1 THEN MOVSPR 1,X1,Y2:MOVSPR 
2,X1,Y2:G0TO 240 


200 IF A=2 THEN MOVSPR 1,X2,Y2:MOVSPR 
2,X2,Y2:60T0 240 


205 IF A=3 THEN MOVSPR 1,X2,YL:MOVSPR 
2,X2,Y1:G0T0 240 


210 IF A=4 THEN MOVSPR 1,X2,Y3:MOVSPR 
2,X2,Y3:60T0 240 


215 IF A=5 THEN MOVSPR 1,X1,Y3:MOVSPR 
2,X1,Y3:G0T0 240 


220 IF A=6 THEN MOVSPR 1,X3,Y3:MOVSPR 
2,X3,Y3:60T0 240 


225 IF A=7 THEN MOVSPR 1,X3,Y1:MOVSPR 
2,X3,Y1:G0T0 240 


230 IF A=B THEN MOVSPR 1,X3,Y2:MOVSPR 
2,X3,Y2 


235: 


240 A$=STR$(A+W):IF LEN(A$)=4 THEN A$= 
RIGHT$ (A$,3) :ELSE:A$="00"+RIGHT$ (A$,1) 


245 CHAR 1,10,1,P$+A$,1 
250 GOTO 180 
255 : 


260 FOR J=3584 TD 3711:READ Q$:POKE 
J,DEC (8$) : NEXT: RETURN 


265: 


270 DATA 00,7E,00,01,FF,80,07,FF,E0,0F 
„FF „FO,1F FF „FB,3F 


275 DATA FF ,FC,3F „FF ,FC,7E,00,7E,7C,00 
,ZE,FC,00,3F ,FC,00 


280 DATA 3F,FC,00,3F ,7C,00,3E,7E,00,7E 
„ZF „FF „FC,3F „FF „FC 
285 DATA 1F „FF „FB,OF „FF ,F0,07,FF,E0,01 
„FF ,B0,00,7E,00,00 
290 DATA 00,7E,00,01,FF,80,07,FF,E0,0F 
„FF „FO,1F FF „FB,3F 


295 DATA FF,FC,3F,FF,FC,7F,FF,FE,7F,FF 
„FE,FF „FF „FF „FF „FF 


300 DATA FF,FF,FF,FF,7F,FF,FE,7F,FF,FE 
A TETCATAT TE 


305 DATA 1F,FF „FB,0F „FF ,F0,07,FF,E0,01 
„FF ,B0,00,7E,00,00 


310: 


315 DATA 
097,038,223,162,100,040,220,160 


320 DATA 
103,042,217,158,094,036,226,164 


100 REM *** 
105 : 
116 REM *** 
lis: 
120 : 


125 5$=CHR$ (147) :PRINTS$: PRINT: INPUT 
"PORT 1 CZY 2 (1/2) : ";P:C$=CHR$ (34) 


130 IF P=1 THEN P=56321:GO0TO0 145 
155 IF P=2 THEN P=56320:G0T0 145 
140 GOTO 125 


145 P$="WARTOŚC "+C$+"NOT 
PEEK ("+RIGHT$ (STR$(P) ,5)+") AND 
1" +C$+" = i" 


150 PRINT 5$:GO5SUB 265 

155 X1=160:Y1=130: X2=197: Y2=90: X3=125:Y 
3=168: V=53248:51=V+1:52=V+2:53=V+3 

160 POKEV+32 ,6:POKEV+33,1:POKE 646,0 
165 : 


1706 POKEV+39, 7:POKEV+40,7:POKEV+23,0:PO 
KEV+29,3: POKEV+23,3: POKEV+21 ,3 


175: 
180 A=NOT PEEK(P) AND 31:W=0:POKEV+40,7 


185 IF A=0 OR A=i6 THEN POKEV,X1:POKESI 
„Y1:POKES2,X1:POKES3,Y1 


170 IF A=>16 THEN W=l6:POKEV+40,Z:A=(A 
AND 15) 


175 IF A=l THEN POKEV,X1:POKESI „YZ: POKE 
52,X1:POKES3,Y2:GOTO 240 


200 IF A=7% THEN POKEV, X2:POKESI „YZ: POKE 
52,X2:POKE53,Y2:GOTO 240 


205 IF A=8 THEN POKEV, X2:POKESI „Yl:POKE 
52,X2:POKE53,Y1:GOTO 240 


210 IF A=i0 THEN POKEV,X2:POKESI „YS: POK 
E52,X2:POKES3,Y3:GOTO 240 


215 IF A=2 THEN PORKEV,X1:POKESI „YS: POKE 
52,X1:POKES3,Y3:GOTO 240 


220 IF A=6 THEN POREV, X3:POKESI „YS: POKE 
52,X3:POKE53,Y3:GOTO 240 


225 IF A=4 THEN POKEV, X3:POKESI „YL: POKE 
52,X3:POKE53,Y1:GOTO 240 


230 IF A=5 THEN POKEV,X3:POKES1 ,Y2: POKE 
52,X3: POKESZ ,Y2 


235 : 


240 Z=A+W:IF LEN(STR$(Z))=2 THEN 
Z$="0"+RIGHT$ (5TR$ (Z) ,L) :GOTO 250 


245 Z$=RIGHT$ (STR$ (Z) ,2) 


250 PRINTTAB (1) ;P$Z$CHR$ (145) CHR$ (157) 
CHR$ (32) 


255 GOTO 180 
260 : 


265 FOR J=832 TO 959:READ Q:POKE 
J,B:sNEXT:POKE 2040,13:POKE 2041,14 


270 FOR I=1 TO 14:T=T+40:FOR X=S5510+T 
TO 55521+T:POKEX ,0:POKEX-54272, 160: NEXT 


275 NEXT: RETURN 
280 : 


285 DATA 000,126,000,001,255,128,007,25 
5,224,015,255,240,031,255,248,063 
290 DATA 255,252,063,255,252,126,000,12 
6,124,000,062,252,000,063,252,000 
295 DATA 063,252,000,063,124,000,062,12 
6,000,126,063,255,252,063,255,252 
300 DATA 031,255,248,015,255,240,007,25 
5,224,001,255,128,000,126,000,000 
305 DATA 000,126,000,001,255,128,007,25 
5,224,015,255,240,031,255,248,063 
310 DATA 255,252,063,255,252,127,255,25 
4,127,255,254,255,255,255,255,255 
315 DATA 255,255,255,255,127,255,254,12 
7,255,254,063,255,252,063,255,252 


320 DATA 031,255,248,015,255,240,007,25 
5,224,001,255,128,000,126,000,000 
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K. DYBOWSKI 


KOREKTA 
KYAN PASCALA 


Jednym z lepszych języków 
dla komputera ATARI — 800XL 
jest Pascal opracowany przez 
firmę KYAN. 


Dysponuję wersją 1.1 tego języka, która niestety 
obarczona jest pewną wadą utrudniającą pracę. 

Wadę tę demonstruje program 1. Proszę wpro- 
wadzić go do komputera, skompilować i uruchomić 
— będzie on wczytywał dwie liczby rzeczywiste i 
drukował ich sumę, różnicę, iloczyn i iloraz. Następ- 
nie proszę wprowadzić dane: 

A=10 
B-0 

Niestety — na ekranie nie pojawi się oczekiwany 

komunikat "ARITHMETIC OVERFLOW" (spowodo- 


PROGRAM PRZYKLADI; 
VAR A,B,C: REAL; 
D: INTEGER; 
BEGIN 
D:z=lz 
REPEAT 
WRITE ("A=") ;zREADLNCA) ; 
WRITE ( "B=" ) ;READLN(B) 3 


C: =A+B; WRITELN ( 'A+B=",C); 
C: =A—B; WRITELN ( 'A— 
B=",C); 


C:=A*xB;WRITELN ( 'A*B=",C)3 
C:=A/B;zWRITELN( 'A/ 

B=",C)3 

UNTIL D=0 

END. 


wany dzieleniem przez zero), zamiast tego z reguły 
ekran gaśnie i system zawiesza się. 

Przyczyna tego niemiłego faktu jest dość prosta: 
Obliczenia numeryczne wykorzystują tak zwany 
dziesiętny tryb pracy procesora. Gdy wystąpi błąd 
obliczeń, zostaje wywołana procedura obsługi błę- 
dów (zawarta w zbiorze LIB), która między innymi 
wykorzystuje procedurę systemu operacyjnego, 
umieszczającą znaki na ekranie monitora. Proce- 
dura ta działa błędnie, gdy wykonywana jest przez 
procesor pracujący w trybie dziesiętnym i zwykle 
doprowadza do zawieszenia systemu. Przyczyną 
błędu jest więc brak instrukcji CLD, przywracającej 
normalny tryb pracy procesora, przed wywołaniem 
procedury drukującej tekst na ekranie. 

Powyższa diagnoza nie byłaby wiele warta gdy- 
bym nie podał od razu odpowiedniej "kuracji". Oto 


PROGRAM PRZYKLADZZ 
VAR A,B,CzREAL3 

Dz: INTEGER; 
BEGIM 
HF 
LBA 
STA 
LDA 
STA 
LDA 
STA 
LBA 
STA 
Li 

D:z=13 

REFEAT 

WRITEĆ Ań=')zREADLN(A)3 

WRITE ('B=")zREADLN(B)Z3 


HO 
Z3POŻO 
FZ1G 
337021 
H+>3Z7021 
40378 
+4 37021 
40377 


C: =A+B: WRITELN ('A+B=" ,C); 
C: =A-B: WRITELN ( 'A— 
B=",C); 


C:=A*B: WRITELN ('A*B=",C); 
C:=A/B: WRITELN ("A/ 
B=",C); 
UNTIL D=0 
END. 


i ona: Na początku procedury obsługi błędów aryt- 
metycznych należy dopisać instrukcję CLD. Adres 
startu jej procedury ulegnie przez to zmianie, ale na 
szczęście jest ona wywoływana zawsze pośrednio, 
przez tablicę skoków — wystarczy więc zmienić ad- 
res w tej tablicy. To wszystko realizuje procedura w 
kodzie maszynowym zawarta w programie 2. 

Niestety, podobnie jak większość lekarstw, tak- 
że i to ma działanie uboczne: dodatkowa instrukcja 
została dopisana kosztem uszkodzenia komunikatu 
błędu "RANGE ERROR", będzie on teraz drukowa- 
ny jako "RANGE ERRO". Wydaje mi się to jednak 
niezbyt wysoką ceną. 

Podaną tu procedurę można wykorzystywać we 
własnych programach. Powinna być ona pierw- 
szym wykonywanym fragmentem programu. Jeśli 
komuś takie rozwiązanie nie odpowiada, to podaję 
inne, pozwalające trwale poprawić zbiór "LIB" Pas- 
cala będący przyczyną tych kłopotów. 

Program 3, napisany w Turbo Basicu XL należy 
uruchomić umieszczając w stacji dysków kopię dys- 
kietki z Pascalem. 

Przypominam, że podane tu poprawki dotyczą 
jedynie wersji 1.1. KYAN Pascala. 

Życzę przyjemnej pracy z Pascalem już nie bo- 
jącym się błędów! 


Wojciech Zabołotny 


REM 
REM 
REM 
REM 


PROGRAM 3 

Poprawia zbior "D:LIB" 
zapisany na dyskietce. 

Radze sprobowac najpierw na 
REM kopii dyskietki z Pascalem! 
DIM AF(7716):AF(7716)=" " 

OPEN ł+1,4,0,"D:LIB" 

BGET +1 „ADRCAF) ,7716 

CLOSE +1 

AF(1157,11537)=CHR$ (0) 
AF(1140,1140)=CHR$F(216):REM CLD 
AF(2517,2517)=CHR$f (37021 MOD 256) 
AF(2518,2518)=CHR$ (37021 DIV 256) 
OPEN +1,8,0,"D:zLIEB" 

BPLT +1 ,ADRC(A$) „7716 

CLOSE ł1:END 


ZAMIANA 


LICZB 


Z przykrością musze stwierdzić, 
że nie znalazłam dotąd w "Bajtku" 
artykułu (programu) napisanego 
przez DZIEWCZYNĘ. Chciałabym 
zmienić ten stan rzeczy proponu- 
jąc program, którego zadaniem 
jest zamiana liczb z systemu dzie- 
siętnego na liczby przedstawione 
w systemie dwójkowym i szes- 
nastkowym (wbudowany BASIC 
nie posiada takiej funkcji). 

Algorytm działania programu jest uniwersalny 
do konwersji liczby w systemie dziesiętnym na 
liczbie w innym systemie, a polega on na dziele- 
niu zadanej wartości przez podstawę określone- 
go systemu. Otrzymane z dzielenia reszty będą 


kolejnymi cyframi reprezentacji zadanej wartości 
w tym systemie. 


Brzmi to trochę dziwnie i niezrozumiale. 
Przedstawmy przykład, który pozwoli lepiej nam 
zrozumieć ten sposób konwersji. 

Chcemy przedstawić liczbę 11 w systemie 
dwójkowym. Dzielimy zatem 11 przez 2 (podsta- 
wę systemu dwójkowego). 

11:2=5 r.1 
5:2=2 r.1 
2:2=1 r.0 
1:2=0 r.1 

Otrzymane reszty (r.) piszemy od pozycji 
najmniej znaczącej (od końca) i w ten sposób 
otrzymujemy liczbę 11 przedstawioną w systemie 
dwójkowym. 

11- -> 1011 

Analogicznie rzecz się przedstawia przy za- 
mianie liczby systemu dziesiętnego na liczbę w 
systemie szesnastkowym z tą tylko różnicą, że 
podstawa dzielenia jest liczbą 16, a dziesiętne 
wartości równe 10,11,12,13,14,15 są przedstawio- 
ne literami A,B,C,D,E,F. 

Dla lepszego zrozumienia przykład: Zamie- 
niamy liczbę 8360 (w systemie dziesiętnym) na 
liczbę przedstawioną w systemie szesnatkowym. 

8360:16 = 522 r.8 
522:16 = 32 r10—A 
32:16 = 2 r.0 
2:16=0r.2 

Przepisanie wartości reszt od pozycji najmniej 
znaczącej da nam liczbę 8360 przedstawioną 
w systemie szesnastkowym (należy pamiętać, 
że wartości 10 odpowiada litera A). Ostatecznie 
otrzymujemy: 

8360 - -> 20A8 


Dorota Ciesielska 


45 
gó 
aja 
60 
63 
70 
75 
BO 


BS 


R=B/2 

C=INT(A) 

IF A£3C THEN T=l 

IF ASC THEN T=0 

AU7-D=T 

E=C 

NEXT I 

7 "Ww mystemie dwojkowym”, 

FOR I=l TO ie 

0 7 ACDĘ 

33 NEXT I 

100 7 

105 FOR I=l TO 4 

110 CHINT(Z/16) 

115 E=Z-16*0 

120 IF Eż=9 THEN T=E+48 

125 IF Es? AND Ezló THEN T=k+5S 

130 DS-D=T 

135 Z=C 

140 NEXT I 

145 7 "w systemie 
szesnastkowym”, 

FOR I=l TO 4 

AF=CHRE(D(T) 

7 Aż 

NEXT I 


150 
155 
160 
1ó5 
1205 


GOTO 15 
7. "WPROWADZILE5 
LICZBE WIEESZA OD 
NAJWIEKSZEJ LICZBY 
16-BITOWEJ (65525) 
GOTO 15 
7 "WPROWADZONA ZLA DANA" 
7 "ZAMIENIAMY DALEJ (TZN); 
INFUT Zż 
IF Z$="T" THEN iQ 
END 


175 
180 


13 
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PORTY JOYSTICKÓW (2) 


W poprzedniej części artykułu 
zacząłem omawiać znaczenie po- 
szczególnych bitów w rejestrze 
PACTL, podając znaczenie tylko 
drugiego bitu. Obecnie postaram 
się przybliżyć znaczenie pozosta- 
łych bitów. 


Funkcje bitów w rejestrze PACTL są następują- 


ce: 

bity 0—1 sterowanie CA1; 

bit 2 gdy jest skasowany (0), to pod adresem 
PORTA jest rejestr porządkowania da- 
nych; 

bity 3-5 sterowanie CA2; 

bit 6 IRQA1, jeżeli podczas odczytywania 
rejestru PACTL bit 6 jest ustawiony (1), 
to znaczy, że wcześniej na CA2 zostało 
podane żądanie przerwania; 

bit 7 RQA2, tak jak bit 6, lecz sterowany 


przez CA1. 


Po tym wstępie należy podać kilka wyjaśnień 
odnośnie CA1 i CA2. Otóż port PIA złożony jest z 
dwóch połówek, które posiadają dwa wejścia lub 
wyjścia kontrolne CA1 i CA2 (zależy to od ustawie- 
nia odpowiednich bitów w rejestrze PACTL). Złącze 
CA1 wykorzystywane jest w Atari jako źródło infor- 
macji dla systemu operacyjnego o przebiegu trans- 
misji przez złącze szeregowe. Natomiast złącze 
CA2 wykorzystane jest do sterowania silnikiem ma- 
gnetofonu. Zajmijmy się znaczeniem bitów i 1 i 0: 


bit 1 bit O 

0 0 — przy opadającym zboczu sygnału 
CA1 bit 7 PACTL zostaje ustawiony 
(na 1). Wyjście przerwania A portu 
PIA pozostaje na "1"; 

0 1 — przy opadającym zboczu sygnału 
CGA1 


bit 7 PACTL zostaje ustawiony (1). 
Wyjście przerwania A portu PIA 
zmienia się na "0" i wywołuje żądanie 
przerwania z CPU; 

1 0 — przy narastającym zboczu sygnału 
CA1 bit 7 PACTL zostaje ustawiony 
(1). Wyjście przerwania A portu PIA 
pozostaje na " 1"; 

1 1 — przy narastającym zboczu sygnału 
CA1 bit 7 PACTL zostaje ustawiony 
(1). Wyjście przerwania A portu PIA 
zmienia się na "0" i wywołuje żądanie 
przerwania z CPU. 


Sterowanie CA2: 
Gdy bit 5 PACTL jest skasowany (0), to CA2 słu- 
ży jako wejście przerwań. Działanie opiera się na 
przedstawionej powyżej tabeli z tą różnicą, że funk- 
cje są kontrolowane nie przez bity O i 2, lecz przez 
bity 3 i 4 rejestru PACTL, zamiast bitu 7 zmieniany 
jest stan bitu 6. 
Gdy bit 5 PACTL jest ustawiony (1), to CA2 służy 
jako wyjście według poniższej tabeli: bit 1 bit O 
0 0 — gdy bit 7 PACTL jest ustawiony 
przez CA1, to przy pierwszym ujem- 
nym zboczu sygnału zegarowego 
po operacji odczytu z PORTA, CA2 
zmienia stan na "0" i ponownie na "1"; 

0 1 — przy pierwszym ujemnym zboczu 
sygnału zegarowego po operacji od- 
czytu z PORTA, CA2 zmienia stan na 
"O" i przy pierwszym ujemnym zbo- 
czu sygnału zegarowego, przy którym 
PIA nie odpowiada zmienia stan na " 
1% 

1 0 — CA2 pozostaje na "0", dopóki nie zo- 
stanie zmieniona a kombinacja bitów; 
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Po dokładnej analizie możliwości sterowania, 
znaczenie różnych zastosowań kanałów kontroli 
CA1 i CA2 staje się wyraźniejsze. Umożliwiają one 
komunikację PIA z różnymi układami peryferyjny- 
mi, przy której CPU w dowolnej chwili otrzymuje sy- 
gnał przerwania, gdy dane wysłane z odbiornika są 
przetworzone lub nowe dane są gotowe do wczy- 
tania przez procesor. Istnieje przy tym możliwość 
wyłączenia przerwań, CPU może sprawdzać, czy 
są spełnione warunki przerwania. Przy wystąpie- 
niu przerwania CPU może zlokalizować jego po- 
chodzenie przez sprawdzenie bitów 6 i 7 PACTL. 
Można także wpływać na kanały kontroli bezpo- 
średnio z urządzeń zewnętrznych, co jest znacz- 
nie szybsze niż sterowanie kanałów kontroli przez 
CPU. Pozwala to znacznie przyspieszyć szybkość 
transmisji danych oraz dokonać automatycznej 
synchronizacji między urządzeniami zewnętrznymi 
i systemem głównym. 

Na razie tyle "mądrych" wiadomości, przejdźmy 
do układów praktycznych przedstawionych na ry- 
sunkach 1—5. 


Krzysztof Kozłowski 
Przemysław Strzelecki 


R=220-3300. 


Rys. 1 — przedstawiono na nim schemat układu umoż- 
liwiającego uzyskanie dużej jasności świecenia diod. 
Wartości rezystorów R należy dobrać tak, aby uzyskać od- 
powiednią jasność, ale nie przekroczyć dopuszczalnej war- 
tości prądu płynącego przez diodę. Uwaga ta odnosi się do 
wszystkich przedstawionych układów. 


+5V 


10x220-330Q 


= 
N 
+ 
Rz 
NI 
Ra 
F 
a) 


oO0 JAM AWNTG 


Rys. 2 — przy zastosowaniu układu UCY 7442 (dekoder 
1 z 10) możliwe jest sekwencyjne sterowanie 10 diodami. 
Wykorzystując program przedstawiony w pierwszej czę- 
ści artykułu uzyskamy efekt przesuwającego się punktu 
świetlnego. Oczywiście zamiast diod można zastosować 
elektroniczne włączniki uruchamiające dowolne urządze- 
nia. W następnej części artykułu postaram się przedstawić 
możliwości sterowania różnymi urządzeniami w zależno- 
ści od stanu określonych czujników. 


Vma=15V 


6417442N 


Rys. 3 — jest to w zasadzie taki sam układ jak opisany 
wyżej. Różnica polega jedynie na zastosowaniu dekodera 
z obwodem otwartego kolektora w stopniu wyjściowym. 
Dzięki temu możliwe jest dołączenie przekaźników na 
inne napięcie niż 5V, jednak nie wyższe niż 15V. Do sty- 
ków przekaźników można dołączyć na przykład żarówki 
sieciowe. 


Wejścia 


12 4 8 funkcjonalne 
Wejścia informacyjne 


w kodzie BCD 8421 


Rys. 4 — jest to najpopularniejszy dekoder kodu binarnego 
na kod wskaźnika siedmiosegmentowego. Umożliwia on 
wzrokową obserwację aktualnej wartości pojawiającej się 
w wybranym porcie joysticków. Można do każdego portu 
dołączyć taki układ i stworzyć prosty program na przykład 
do podglądania zawartości określonych rejestrów, stoper 
czy programowalny zegar do ciemni fotograficznej. 


wejścia 
danych 


6474154 


64174154 


wejścia adresowe 
wyjścia danych 


64174154 


Rys. 5 — przedstawiony schemat jest propozycją wykorzysta- 
nia portów joysticków do sterowania 256 urządzeń. Bliższe 
informacje na temat tego układu, układów przedstawio- 
nych wcześniej oraz innych ciekawych rozwiązań moż- 
na znaleźć w książce W. Sasala pt. „Układy scalone serii 
UCA64/UCY?74, parametry i zastosowania”, WKiŁ, 1985. 


Po_opublikowaniu w „Bajtku” 
10/87 odpowiedzi na list Arkadiu- 
sza Sochana otrzymaliśmy od 
Czytelników wiele listów. Kolega 
Marcin nie majac do czynienia na 


codzień z komputerami Atari udzie- 
lił niepełnego wyjaśnienia, co nasi 
Czytelnicy natychmiast zauważyli. 
Drukujmy wiec dwa wybrane listy 
oraz komentarz redakcyjny. 


BASIC ZX-SPECTRUM posiada instrukcję 
SAVE "nazwa" GOTO, która powoduje autostart 
programów. Nie wszyscy użytkownicy Atari 
widzą, że jego BASIC posiada identyczną in- 
strukcję: SAVE "C:" (zapis) i Run "C:" (odczyt). 
W przypadku ATARI sprawa jest o tyle skom- 
plikowana, że instrukcja SAVE'C:" daje sygnał 
o długich przerwach, co poważnie wydłuża 
transmisję danych. Można to ominąć używając 
krótkiego programu zapisanego instrukcją SA- 
VE'C:" (tak zwanego Loadera) do ładowania i 
autostartu właściwego programu zapisanego w 
konwencji CSAVE — CLOAD. 

Napiszmy więc odpowiedni Loader pamięta- 
jąc jedynie, aby był on jak najkrótszy ze wzglę- 
du na format danych instrukcji SAVE"C:" i że 
po CLOAD sam się skasuje; np taki (litery przed 
nr linii to sumy kontrolne Edytora BASICa, nie 
należą do programu i nie należy je wpisywać). 


UTOSTAR 


PROGRAMÓW 


FO 18 ? CHR*C(125):POKE 
718,8:POKE 783,8:POSITION 2,18;? 
"RLN'':POSITION 8,8: 
POKE 74,27:POKE 842,13:CLOAD 


Teraz zapiszmy Loader na taśmie przed 
właściwym programem autostartujacym in- 
strukcją SAVE"C:" (tej taśmy nie przewijamy), 
a następnie wykonujemy NEW (czy wyłączamy 
komputer) i ładujemy właściwy program. Dopi- 
sujemy do niego linię: O POKE 842,12:GR.0 

Następnie zapiszemy, po programie Loader, 
program właściwy instrukcją CSAVE, najlepiej 
kasując ostatni sygnał programu ładującego 
Loader, jeżeli nie jest interpretowany (sprawdź- 
cie, nie powinien). 

Traktujcie program ładujący jak pilota do gry 
— nie powinno być odstępu między pilotem a 
programem właściwym — a co najwyżej nie- 
wielki. 


Teraz wyłączcie komputer i ładujcie całość 
RUN'C:" 


Dlaczego działa? 

Komputer wczytuje Loader, uruchamia go i da- 

lej kolejno wykonuje: 

1. Czyszczenie ekranu 

2.Czyni litery niewidzialnymi (POKE 710,0, 
POKE 709,0) 

3. U dołu ekranu wpisuje RUN (tego nie widać, 
POS. 2, 10.PRINT"RUN") 

4. Przenosi kursor do góry (POS.0,0) 

5. Informuje komputer, że został naciśnięty ja- 


kiś klawisz (po CLOAD komputer nie czeka na 
to; POKE 764,27). 

6. Uruchamia RETURN (POKE 842,13) 

7. Wykonuje CLOAD 


Dowcip polega na tym, że RETURN jest wy- 
konywane dopiero po zakończeniu programu, 
czyli po transmisji CLOAD. Wtedy RETURN do- 
chodzi do RUN na ekranie i wykonuje go. Pierw- 
sza linia programu przywraca stan normalny 
wyłączając RETURN i kasując ekran. 


Jakub Cebula 


Przedstawiony program jest tzw. "loade- 
rem", który steruje ładowaniem programów i 
następnie uruchamia je. Program zajmuje ob- 
szar od adresu 1536 do 1751. Ponadto blokuje 
on klawisz RESET, który po wciśnięciu, kasuje 
pamięć RAM. Po dokładnym przepisaniu pro- 
cedury, należy przygotować magnetofon do za- 
pisu i uruchomić program rozkazem RUN. Zo- 
stanie on zapisany na taśmie w postaci BOOT, 
przeznaczonej do ładowania poprzez wciśnię- 
cie klawisza START w momencie włączenia 
komputera. 


Tomasz Waligóra 


1 REM ** (CJ) TOMASZ HALIGORĄ ** 
2 REM *x* 19387 HLOSZĄAKOHICE *** 
FOR G=6 TO Z14:REALB A:S=S+Ą 
POKE 1536+G,A:NEXT G 

IF 5-13114 THEN 58 

3% „BLAB H BANYCH !":ENE 

OPEN H1,8,128,'C:'"' 

POKE 858,11:POKE 852,8 

POKE 853,6:POKE 856,215 

POKE 857,8:POKE 858,8 

R=LUSR CAPR C „AhhŹLVET"I „ 163 
CLOSE H1:? „O.K.":ENE 

REM **x* DANE *x* 

BATA 8,2,8,6,16,6,163,68 
BATA 141,2,211,163,8,133,65 
BATA 36,163,148,141,137,2 
BATA 173,48,2,135,128,173 
BATA 43,2,138,123,166,4,177 
BATA 128,133,138,288,177 
BATA 128,135,131,238,131 
BATA 238,131,168,163,162,8 
BATA 189,31,6,145,1368,232 
BATA 136,268,247,163,13,141 
BATA 74,2,163,8,133,84,163 
BATA 254,141,173,2,163,127 
BATA 141,188,2,76, 
BATA 8,8,8,8 
BATA 8 
BATA 8 
BATA 8 
BATA 8 
BATA 3 
BATA 
BATA 
BATA 
BATA 
BATA 
BATA 
BATA 
BATA 
BATA 
BATA 


Ej 

EJ 

EJ 

EJ 

Ej 

5 

Ej 
12,28,22,23,8,37,43,47 
48,26,18,17,12,18,28 
24,8,37,43,8,8,47,48 
26,2,155,68,44,255,137 
155,158,8,68,137,48,52 
1357,48,151,137,218,253 
138,2,23,4,56,26,3,16 
28,8,4,56,8,45,41,36,8 
8,8,8,6,68,6,68,6 


Z78 
386 


Wszystkie rozwiązania tego problemu wymaga- 
ją nagrania przed właściwym programem dodat- 
kowego programu ładującego. Niestety, ominięcie 
tego jest niemożliwe. Najczęściej stosowane jest 
połączenie obu pokazanych wyżej sposobów, co 
pozwala na wyświetlenie tytułowej winiety progra- 
mu już podczas jego wczytywania do komputera. 
Cały program składa się wówczas z trzech bloków: 
"loadera" w języku maszynowym (list 2), programu 
wyświetlającego tytuł i programu właściwego (oba 
nagrane przez CSAVE). Jednak procedura kolegi 
Jacka uniemożliwia to, gdyż wykorzystuje ekran 
do podania komputerowi rozkazów. W takim przy- 
padku należy użyć instrukcji, którą już w 1983 roku 
opublikował amerykański miesięcznik "Aniic". 


PG 1888 POKE 65,9:POKE 754,32:XH=1I5R 
CADR C"ZLĄSFIHHTHEH GAFIIL4A'23 


Zastępuje ona brakującą w Atari BASIC instruk- 
cję CRUN. 


Wojciech Zientara 
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Często porównuje sie szyb- 
kość pracy różnych jezyków 
programowania. Przyjmuje sie 
przy tym przeważnie, że języki 
kompilowane sa szybsze niż in- 


terpretowane. Jak jest rzeczy- 
wiście? 


Przeprowadziłem test szybkości pięciu popu- 
larnych języków programowania. Jakie to języki? 
Przede wszystkim wbudowany na stałe do kom- 
putera Atari Basic. Ze względu na znaczną po- 
pularność uwzględniony został Turbo Basic XL. 
Jako trzeci język interpretowany został wybrany 
szeroko reklamowany Basic XE. 

Z języków kompilowanych wybrałem C, który 
jest uważany za jeden z lepszych języków pro- 
gramowania, oraz dostępny jedynie dla kompute- 
rów Atari, bardzo popularny na Zachodzie język 
Action! Celowo został pominięty Pascal, gdyż 
jego wersja na Atari ma wszystkie procedury 
specyficzne dla tego typu komputera napisane 
bezpośrednio w języku maszynowym, co znie- 
kształciłoby uzyskane wyniki. Dodatkowo wyko- 
nałem test programu w Atari Basic skompilowa- 
nego przy pomocy MMG Basic Compiler. 

Do testu napisałem specjalny program. Za- 
pełnia on najpierw punktami obraz w trybie wy- 
sokiej rozdzielczości (przy pomocy instrukcji 
graficznych), a następnie czyści go operując 
bezpośrednio na pamięci obrazu. Wydruki tego 
programu w pięciu wyżej wymienionych językach 
zamieszczone są obok. 

Po tym wprowadzeniu czas na wyniki. Zawar- 
te są one w poniższej tabelce. Mimo pominięcia 
Pascala oszacowałem także szybkość programu 
testowego w wersji Kyan Pascal. Program wyko- 
nywany jest przez około 8500 taktów zegara. 


Język liczba taktów 
Atari Basic 24840 

Basic skompilowany 5689 

Basic XE 10807 

Turbo Basic XL 9197 
C(DeepBlue) 16709 

Action 4565 


Zgodnie z oczekiwaniami najwolniejszy oka- 
zał się Atari Basic Zaskoczeniem jest natomiast 
mała szybkość C — czas wykonywania progra- 
mu (skompilowanego) był o 50 proc. dłuższy niż 
w interpretowanym Basicu XE i Turbo Basicu XL. 
Różnica pomiędzy tymi ostatnimi jest niewielka i 
praktycznie pomijalna. Stary Atari Basic pokazał 
jednak swoją wyższość po skompilowaniu — był 
prawie dwa razy szybszy od pozostałych Basi- 
ców. 

Bezkonkurencyjny okazał się jednak Action! 
Nie ma żadnej przesady w twierdzeniu, że jest to 
najszybszy język Atari. W niektórych programach 
dorównuje on szybkością językowi maszynowe- 
mu. Z wydruku widać, że jest on składnią i struk- 
turą zbliżony do Basica, nie ma więc kłopotów z 
przestawieniem się na inny sposób programo- 
wania przy przejściu z Basica na Action! Trzeba 
tu dodać, że Action! dysponuje jeszcze dodatko- 
wymi procedurami operacji na blokach pamięć. 
Gdyby zostały one zastosowane w programie, to 
różnica szybkości byłaby jeszcze większa. 

Wszystkich wątpiących w zalety Action! nama- 
wiam do samodzielnego wypróbowania tego języ 
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sTest szybkosci — Action! 


BYTE 
CARD 


cli=20,c12=19, i 
j,time,sm,dl=s40 


PROC Test () 
cli=Q clż =0 
Graphicz (24) 
FOR i=0 TD 171 

DO 
FOR j=0 TD 517 


Lolor=1 


sm=PeekL (dl+4) j=0 
WHILE  j=76480 

DO 

Pokefsi+j , 0) 

j==+1 

OD 
time=cli+żnótci2 
Graphicz (0) 
PrintEt) 
Print("Czas wykonania testu: ") 
PrintC (time) 
PrintE(" taktow.") 
RETURN 


f* Test szybkosci — CC */ 
char i,*cli, *cl2z 
int j, time, sm; 


main () 
$( 
cli=20; 
c1l2=17; 
*cl 1=0; 
*cl2=03 
graphics (24)3 
color (1)3 
for (i=03i4=1971;++i) 
$( 
for (j=0; j£=3173++]j) 
$( 
plott(j,i); 
$) 
$) 
sm=dpeek (dpeek (560)+4)3 
i=0; 
while(j<76B0) 
$( 
poke(sm+j,0)5 
++j; 
$) 
time=*cl1l+Z54*(*cl2); 
graphicz(0)5 
printfti"in")3 
printf("Czas wykonania testu: 
printfl"zd" ,time)z 
printf(" taktow. in"); 
$) 


sy: 


ka, ja natomiast postaram się zamieścić wkrótce 
w „Bajtku” jakiś program w tym języku. Polecam 
także kurs programowania w Action! ukazujący 
się w odcinkach w „Bajtku-Atari”. 


Wojciech Zientara 


AGuon: uc szyekość 


16 REM Test 
20 
30 
40 
s0 
60 
70 


szybkosci m 
POKE 20,0:POKE 17,0 
GRAPHICS 24:COLOR 1 

FOR I=Q TO 171 

FOR J=Q0 TO 35197 

PLOT J,1i 

NEXT J 

80 NEXT I 

30. DL=PEEE (540) +256*PEEK (561) 

100 - SM=PEEK (DL+4) +256*PEEK (DL+5) 
:J=Q 
1io 
120 
150 
140 
150 
160 
170 
180 
170 
200 


POKE SM+J,0 
J=J+1 

IF J£7680 THEN 110 
TIME=PEEK (20) +256*PEEK (17) 
GRAPHIC5 O 
PRINT 
PRINT "Czas wykonania testu: "z; 
PRINT TIME; 
PRINT " taktow." 
END 


10 REM Test szybkosci — Turbo Basic 
TIMEŻ= "DOOOODQ" 
GRAPHICS 24:C0LOR 1 
FOR I=Q TO 171 

FOR J=Q TO 519 

PLOT J,I 

NEXT J 
NEXT I 
SM=DPEEK (DPEEK (560) +4) : J=Q 
WHILE J<7680 

POKE 5SM+J,0 

J=J+1 
WEND 

J=TIME 

GRAPHICS 0 

PRINT 
PRINT "Czas wykonania testu: "z; 
PRINT J; 
PRINT " taktow." 
END 


10 Rem Test szybkosci — Basic XE 
Dpoke 17,0 
Graphics 24:Color i 
For 1=0 To 191 
For J=Q To 3197 
Plot J,1 
Next J 
Next I 
Sm=Dpeek (Dpeek<560) +4) : J=Q 
While J<7680 
Poke Sm+J,0 
J=J+1 
Endwhi ie 
Time=Peek (20) +2Gó*Peek (17) 
Graphics 0 160 Print 
Print "Czas wykonania testu: 
Print Time; 
Print " taktow." 
End 


160 
1iQ 
120 
150 
140 
150 
170 
180 
170 
200 


KLAN AMSTRAD/SCHNEIDER 


NERWY 
(po raz drugi 


PROGRAM 
KOJĄCY 


Ponieważ program opublikowany 
w numerze 1/88 wywołał bardzo duże 
zainteresowanie czytelników, powta- 
rzamy go z myślą o pechowcach, któ- 
rym nie udało się kupić styczniowego 
Bajtka. Program służy do sprawdza- 
nia poprawności wprowadzania do 
komputera wydruków zawierających 
"sumę kontrolną" w każdej z linii. 
Przypominam jednocześnie, że pole- 
ceniem | OFF można wyłączyć wery- 
fikator i w dowolnym momencie włą- 
czyć ponownie poleceniem | ON. 


(wz) 


Ach, co to był 


za błąd?! 


Doświadczeni programiści 
wiedzą, że aby znaleźć odpo- 
wiedź na takie pytanie trzeba 
niejednokrotnie poświęcić dużo 
czasu, chociaż odpowiedź może 
okazać się bardzo prosta. 


W dużo gorszej sytuacji sa począt- 
kujący amatorzy „komputerowego sza- 
leństwa”, stawiający pierwsze kroki nie 
tylko w programowaniu, ale również i w 
nieodzownym przy tej pracy języku an- 
gielskim. Krótkie „syntax error” lub inne 
niezrozumiałe komunikaty rujnują zapał, 
nerwy, i czupryny naszych najmłodszych 
czytelników. A właściwie jest to już czas 
przeszły... Wystarczy uzbroić się w odro- 
binę cierpliwości i przepisać poniższy 
program oraz utrwalić go na kasecie lub 
dyskietce pod nazwą „SUFLER”. Od tej 
pory pisanie własnych programów nale- 
ży rozpoczynać od załadowania naszego 
„suflera”, numerując własne linie począw- 
szy od 10. i kończąc obowiązkowo linią z 
rozkazem END o numerze nie większym 
niż 59999! Każde uruchomienie progra- 
mu z błędem spowoduje pojawienie się 
informacji o numerze błędu, numerze linii, 
w której wystąpił błąd oraz komunikatu w 
języku angielskim z następującym po nim 
obszerniejszym wyjaśnieniem w języku 
polskim. 

Sprawdzony i działający program 
zapisuje się oczywiście na kasecie lub 
dyskietce po uprzednim usunięciu „sufle- 
ra” poleceniami DEL — 9 i DEL 60000 
—. Zapisane wcześniej a nie działające 
programy mogą być poprawiane również 
przy użyciu tego programu po włączeniu 
do nich „suflera” poleceniem CHAIN MER- 
GE „nazwa programu” (pod warunkiem 
wszakże, że kończą się również linią z 
poleceniem END). 

Roztargnionym przypominam, iż nie 
należy przepisywać z listingu liczb po- 
danych w nawiasach kwadratowych, ani 
samych nawiasów. Są to liczby kontrolne, 
generowane przez opisywany poniżej po 
raz drugi weryfikator, służące wyłącznie 
do kontroli poprawności wpisywanych linii 


programu. 
Wojciech Ziółek 


10 'Weryfikator V.2 dla CFC 6128 
20 WIDTH 40 

30 MEMORY £A4FF 

40 FOR aż=kAS00 TO ŁA607 

g0 READ byteż 

60 POKE aż,VALI"E"+byte$) 

70 NEXT 

BO CLS:PRINT 

90 PRINT "Weryfikator V.2 
zainstalowany" 

100 PRINT "Zaladuj swoj program” 
110 PRINT "Rozkaz ICHECK,2 
listuje program" 

120 PRINT "i sprawdza sume 
kontralna." 

1350 PRINT "Rozkaz ICHECK,B 
listuje program" 

140 PRINT "z suma i drukuje na 
drukarce." 

150 CALL ŁAGOO: ION 

160 DELETE 

170 DATA 21,09,a5,01,0d,ag,ch,di 
180 DATA be,00,00,00,00,18,a5,c3 
190 DATA 2Za,aj,cj,2f ,ag,cJ,43,a5 
200 DATA 4f,ce,4f,46,06,43,48,43 
210 DATA 43,cb,00,00,cf,02,ac,c3 
220 DATA a8,a5,21,27,a5,18,03,21 


[1511] 1 OM ERROR GOTO 40000 
[607] 2 'Dd tego miejsca mozesz 
[1654] 3 "wprowadzac swoj 
program 

[6361 4 'az do linii nr 579799 
[2877] 60000 CLS:PRINT "Blad nr 
":3ERR;z" w linii ne"zERL 
[101221 60010 ON ERR GOTO 65000 


,65010,65020 ,65030,65040,65050, 
65060 ,65070,65080,65090,65100,6 
5110,65120,65130,65140,65150,65 
160,65170,65180,65190,65200,652 
10,65220,65230,65240,65250,6526 
0,65270,65280,65290,65300,65310 


[134811 63000 PRINT:PRINT 
"  lnexpected Next Proba 
wykonania instrukcji NEXT, dla 
ktorej brak odpowiadajacej jej 
instrukcji (FOR lub zmienna 
wystepujaca po NEXT jest inna 
niz w instrukcji FOR":END 
173771 65010 PRINT:PRINT 
"  Byntax Error Skladnia 
polecenia  niezrozumiala dla 
Basic 'a":END 

[14155] 65020  PRINT:PRINT " 
Unexpected Return Proba 
wykonania instrukcji RETURN, 
dla ktorej nie bylo wywolania 
podprogramu instrukcja 
GOSUE" : END 

[83211 65030 PRINT:PRINT " Data 
Exausted Brak lub za mala 
danych dla instrukcji READ":END 
[16217] 65040 PRINT:PRINT " 
Improper  frgument Ogolny 
komunikat o bledzie - brak 
zgodności argumentow wykonywanej 
funkcji z jej parametrami lub 
bledne parametry polecenia':END 
[16600] 65050  PRINT:PRINT " 
Overflow Wynik operacji 
arytmetycznych przekracza 
dopuszczalny zakres liczb 
rzeczywistych lub przy zamianie 
dopuszczalny zakres liczb 
calkowitych":END 

[77851 65060  PRINT:PRINT * 
Memory Full Za duzy program 
lub zbyt wiele zmiennych lub 
zbyt wiele petli typu GO05UB, 
WHILE i FOR":END 

[6121] 65070 PRINT:PRINT " Line 


DATA 24,a5,28,06,cd,00,b9,c3 
DATA 49,cb,11,5e,bd,01,03,00 
DATA ed,bó,c7,4f ,cd,00,b7,0d 
DATA 28,08,0d,20,ea,dd,/e,02 
DATA 18,04,7b,11,01,00,cd,a6 
DATA ci,cd,64,e8,05,48,23,46 
DATA 25,3e,23,56,e1,78,bi,c8 
DATA cd,72,c4,65,09,e83,cd,54 
DATA eż,21,Ba,ac,cd,7a,a5,el 
DATA 18,eż,e5,cd,ba,ag,e3,cd 
DATA 78,a5,cd,33,f3,83,cd,f6 
DATA aj,cd,78,c3,e1,78,a7/,0c8 
DATA cd,78,a5,cd,78,c3,18,f5 
DATA 3a,07,ac,d6,08,47,78,a7 
DATA cB,cd,1d,eż,23,10,f7,c9 
DATA cd,24,a5,f3,c5,d3,e9,cd 
DATA ba,as,cd,fó,a5,el,di,ci 
DATA f1,c9,eb,ib,af,47,67,6f 
DATA 2f,52,23,a5,13,1a,d6,30 
DATA 38,04,fe,0a,38,f6,1a,13 
DATA a7,c8,4f,3a,23,a5,al,fe 
DATA 20,28,f3,79,fe,22,20,07 
DATA 3a,23,a3,2f,32,23,a9,3a 
DATA 23,a5,a7,797,c4,ab,ff,4f 
DATA ad,07,6f,09,18,d8,3e8,20 
DATĄ cd,a0,c3,3e,5b,cd,a0,c3 
DATA cd,44,ef,3e,5d,c3,a0,c3 


HI 


td 


id FI 


„Fa |" 0) 
L"SL"JL="J — Jon 


La ol LA ld LA CA LA Le 
ż» 


SJ GO l > LH 
w 


Led 


Does not Exist Erak linii o 
takim numerze":END 

I[Beż6] (65080  PRINT:PRINT " 
Subscript Dut of Range : Jeden 
ze wskaznikow zadeklarowanej 
tablicy jest za duzy lub za 
maly":END 

[7712] 65070  PRINT:PRINT " 
Array Already Dimensioned 
Zadeklarowanie po raz drugi tej 
samej tablicy":END 

[B183] (65100  PRINT"PRINT " 
Division By Zero Jedna ze 
zmiennych w linii wykonujacej 
dzielenie rowna jest zeru lub 
wynik przekracza zakres wartosci 
liczbowych” :END 

[7023] 65110  PRINT:PRINT " 
Invalid Direct Command 
Polecenie nie moze bye wykonane 
w trybie bezposrednim":END 
[14660] 65120 PRINT:PRINT " 
Type Mismatch : Zamiast zmennej 
numerycznej wprowadzona zmienna 
alfanumerycna (lub odwrotnie) 
lub blad przy wprowadzaniu 
wartosci dla instrukcji READ 
lub INPUT":END 

[106101 65130 PRINT:PRINT 
" String Space Full Nie ma 
juz miejsca na przechowywanie 
wyrazen lancuchowych" :END 
[6222] 65140  PRINT:PRINT " 
String Too Long : Lancuch znakowy 
przekracza 235 znakow" :END 
[14452] 65150 PRINT:PRINT " 
String Expression Too Complex : 
Zbyt zlozone wyrazenie tekstowe 
dajace przy manipulacji nim 
za duzo posrednich wartosci 
tekstowych" :END 

[15022] 65160 PRINT:PRINT " 
Cannot CONT(inue) Nie moznia 
wznowi dzialania programu 
orzez uzycie COUNT, poniewaz 
zmodyfikowano jego tresc':END 
[10617] 65170 PRINT:PRINT " 
Unknown User Function Proba 
uzycia funkcji FN uzytkownika bez 
jej uprzedniego zdefiniowania 
(DEF FM)":END 

[7048] 65180  PRINT:PRINT " 
RESUME missing : Brak instrukcji 


Zmiany linii DATA dla CFL 464 

240 DATA 45,cb,00,00,cf,98,aa,c3 
270 DATA 06,dd,11,3a,bd,01,03,00 
300 DATA 18,04,7b,11,01,00,cd,a2 
310 DATA cl,cd,a3,67,e65,4e,23,46 
350 DATA cd,śc,c4,85,09,e3,cd,63 
340 DATA el,21,a4,ac,cd,/a,ag,el 
360 DATA 78,a5,cd,76,f2,e83,cd,f6 
370 DATĄ as,cd,4e,c3,81,7/8,a7,c8 
380 DATA cd,78,a5,cd,4e,c3,18,f3 
390 DATA 3a,24,ac,d6,08,47,78,a7 
400 DATA c8,cd,43,e1,23,10,f7,c9 
470 DATA 23,a5,a7,79,c4,8a,ff,4f 
g10 DATĄ cd,sc,cj,de,5b,cd,sc,ch 
20 DATĄ cd,/9,8e8,3e,5d,03,5C,C3 


Zmiany linii DATA dla CFL 664 

270 DATA 4c,ch,1i,5b,bd,01,03,00 
300 DATA 18,04,7b,11,01,00,cd,a9 
310 DATA ci,cd,67,e8,e65,4e,23,46 
350 DATA cd,7/5,04,85,09,e3,cd,39 
360 DATA 78,a5,cd,58,f3,e3,cd,f6 
370 DATĄ ag,cd,7b,c3,e1,7/8,a7,c8 
380 DATA cd,78,a5,cd,9b,c3,18,f3 
400 DATA cB,cd,22,e2,23,10,f7,c9 
g10 DATĄ cd,aś,cj,de,5b,cd,aś,ch 
320 DATA cd,49,ef,3e,5d,cJ,ad,c3 


RESUME w 
bledow" :END 
[BI22] (65170  PRINT:PRINT " 
Unexpected RESUME : Program 
zawiera instrukcje RESUME bez 
poprzedniego wpisania ON ERROR 
GOTD...":END 

[154611] 65200 PRINT:PRINT " 
Direct Command Found : Podczas 
ladowania programu  wystapila 
linia bez numeru traktowana 
jako zlecenie bezposrednie":END 
[6355] 65210  PRINT:PRINT " 
Operand Missing : Brak fragmentu 
polecenia, zla skladnia":END 
[5045] 65220 PRINT:PRINT " Line 
Too Long : Linia za dluga (>255 
znakow) ":END 

[7781] 652530 PRINT:PRINT " EOF 
Met Proba odczytu nastepnej 
informacji do napotkaniu 
znacznika konca z bioru":END 
[76641 65240 PRINT:PRINT " File 
Type Error : Proba wykorzystania 
zbioru o innym niz dozwolony 
typie":END 

[46611 65250 PRINT:PRINT " NEAT 
Missing : Brak instrukcji NEXT 
zamykajaca  petle  rozpoczeta 
przez FOR":END 

[88081 65260 PRINT:PRINT " File 
Already Open Proba otwarcia 
kolejnego zbioru bez zamkniecia 
poprzedniego" :END 

[6384] (65270  PRINT:PRINT " 
Unknown Command nieznane 
polecenie lub slowo 
kluczone":END 

[72791 65280 PRINT:PRINT " WEND 
Missing : Brak instrukcji WEND 
zamykajacej petle, rozpoczyajaca 
sie od WHILE... ":END 

[8405] (65290  PRINT:PRINT " 
Unexpected WEND Napotkanie 
instrukcji WEND, dla ktorej brak 
odpowiadajacej jej instrukcji 
WHILE" :END 

63300 PRINT:PRINT " File Not 
Ope [76221n Proba uzyskania 
dostepu do zbioru, ktory nie 
zostal otwarty":END 

[3564] 65310  PRINT:PRINT " 
Eroken In : FPrzerwanie":END 


programie obslugi 
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Następna gra firmy Ultima- 
te — GUN FRIGHT, jest bardzo 
podobna do NIGHT SHADE. Tu 
jednak nie ma mowy o duchach 
— wrogiem do zlokalizowania i 
unieszkodliwienia jest material- 
na postać. Chodzi w kapeluszu i 
zawsze z ręką na colcie. Jest jed- 
nym z najsławniejszych i najszyb- 
szych łotrów Dzikiego Zachodu. 
Do szajki należą Buffalo Bill, Billy 
Kid, Sundance Kid, Butch Casi- 
dy, Ma Baker, Wild Bill, Rumpo 
Kid, Clever Jake, i wielu innych. 
Ty, jako szeryf miasteczka Draw 
City musisz ich wszystkich po- 
słać do piachu, gdyż nie dadzą Ci 
spokoju. Codziennie rozlepiasz 
na ścianach listy gończe, ofia- 
rowując coraz większą nagrodę 


za schwytanie bandyty. Niestety, 
mieszkańcy Draw City nie są ka- 
pusiami, tylko mali chłopcy po- 
kazują Ci palcem, w którą stronę 
poszedł poszukiwany morderca. 
Gdy jako szeryf Quickdraw 
maszerujesz ulicami miasteczka, 
ściany budynków zastępowane 
są liniami, byś mógł cały czas ob- 
serwować bohatera. Twoje uzbro- 
jenie to sześciostrzałowy colt Ma- 
gnum 0,72 mm. Po wystrzeleniu 
całego magazynka broń samo- 
czynnie się ładuje, odliczając jed- 
nak od posiadanej przez Ciebie 
kwoty sumę potrzebną na zapła- 
cenie za naboje. Aby zdobyć pie- 
niądze, na początku gry strzelasz 


do spadających worków ze zło- 
tem. Jest to dobry trening przed 
starciem z poszukiwanymi. 

Przez cały czas z lewej strony 
ekranu widzisz list gończy z wi- 
zerunkiem poszukiwanego ban- 
dyty i cenę za jego głowę. Pod 
tym plakatem wisi kilka kapelu- 
szy. Jest to liczba ewentualnych 
przegranych pojedynków, jaka Ci 
pozostała. Jeszcze niżej pokaza- 
ny jest magazynek colta i ilość 
gotówki, jaką dysponujesz oraz 
ceny naboi, koni i grzywna za 
zabicie niewinnego mieszkańca 
miasteczka. 


<> 


Grzywna ta jest 
— od 100 do 5000 dolarów. | 
jednak nie ma wyjścia. Gdy któryś 


z mieszkańców wejdzie Ci w drogę, - 


musisz wybrać — atbo Ty, albo on. 

Na ulicy można znaleźć konia na 
dwóch nogach. Po dotknięciu go 
i odliczeniu sumy na zapłacenie, 
galopujesz po mieście bez obawy 
przed jego mieszkańcami. Czasami 
i bandyta jest konno, więc uważaj, 
bo może Ci uciec. 

Jeśli całą forsę przepuścisz na 
naboje, konie i kary, nie martw się, 
tylko dobrze rozejrzyj po okolicy. 
Na pewno znajdziesz porzucone 
worki ze złotem. 

Gdy bandyta znajdzie się w za- 
sięgu Twojego wzroku, od razu 
strzelaj, gdyż jest on bardzo szyb- 
ki i celny. Sam pojedynek odbywa 
się w pobliskim barze. Przed sobą 
widzisz mordercę i swój celownik. 
Strzelaj bez namysłu. Zanim ban- 
dyta wyciągnie rewolwer, minie jed- 
na sekunda, przez ten czas musisz 
go trafić chociaż w nogę. Jeśli nie 
zdążysz, on podziurawi Twój życio- 
rys odejmując Ci jeden kapelusz. 
Jeżeli jednak szybkością strzałów 
i ich celnością poślesz do ziemi 
mordercę, nie ciesz się za bardzo. 
Oto kolejny bandyta zaczyna rozra- 
biać, Tobie przypada unieszkodli- 
wienie go; oczywiście stawka jest 
już większa. I jeszcze jedna uwaga: 
podczas penetrowania miasta uwa- 
żaj na kaktusy, gdyż dotknięcie gro- 
zi śmiercią i tylko leżący na ziemi 
kapelusz będzie pamiątką po nie- 
uważnym szeryfie. Zwrócić też uwa- 
gę na rój dzikich szerszeni, który 
wypuszczają żądni zemsty kumple 
zabitych łotrów. 

Gra nigdy się nie kończy (chyba, 
że przegrasz), gdyż ciągle rodzą się 
nowi bandyci i wciąż trzeba dbać o 
porządek ,v mieście. Firma: Ultima- 
te 

Komputer: ZX Spectrum  48/ 
Commodore 64/128. 
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Kopertę nadesłała Hanna Kucewicz z Elbląga 


To już 25-te notowanie Bajtkowej Listy Przebo- 


jów. Zainteresowanie nią nie słabnie. Wciąż otrzy- 
mujemy od Was setki listów z propozycjami — w 
tym miesiącu nadeszło ich 1750. Głosowano na 194 


tytuły. 
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Nagrody wylosowali: Małgorzata Łącka i Marcin Jarek. 
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Czy pamiętasz Paper—boy'a? Chy- 
ba pomagałeś mu rozwozić gazety do lon- 
dyńskich domów? Nasz kolega nie chodził 
do szkoły, tylko uczył się zarabiać na własne 
utrzymanie. Skutki tego widać do dzisiaj — 
ma rodzinę i zajmuje się... zbieraniem śmieci. 
Przechodzi codziennie tę samą ulicę i opróżnia 
kosze usytuowane koło domów. Nie potrzeba 
wiele wiedzy, prawda? Jednak liczy się szyb- 
kość i zręczność! Trashman wie, że nawet w 
tym fachu może zrobić karierę, może również 
sporo zarobić. Opanował sposoby zdobywania 
napiwków, potrafi też pracować na tyle szybko, 
by zostać przeniesionym na bardziej eleganc- 
ką i lepiej płatną ulicę. Ty zapewne nie dorobi- 
łeś się jeszcze trzech liter przed nazwiskiem 
(jeśli tak, może się Pan zawsze wytłumaczyć 
chęcią zabawy) — chwyć więc za joystick i 
zdobądź tytuł trashmana roku! Zaczynamy od 
małej Montague Road. 

Jesteś tu po raz pierwszy? To zrozumiałe, 
ale liczy się szybka orientacja. Przez furtkę do 
domu po lewej stronie, kosz stoi z drugiej stro- 
ny. Nie po trawniku! Angielskie trawniki są ela- 
styczne i wytrzymałe, ale nie denerwuj gospo- 
darza... Teraz z powrotem tą samą drogą do 
samochodu, który przystanął przy krawężniku. 
Podejdź do niego od tyłu. a gdy kosz zosta- 
nie opróżniony, odnieś go na swoje miejsce. 
I szybko na drugą stronę ulicy. Stop! To jest 
Londyn, uważaj na samochody! Z drugim ko- 
szem ta sama operacja. Jeśli nie widać ścież- 
ki, idź blisko ściany budynku. Potem szybko 
w górę ekranu do następnego domu. Masz 
już kosz w ręku, ale samochód ucieka Ci. nie 
możesz wcelować w furtkę i... Miało być szyb- 
ko, atu: bonus — O, joystick nie reaguje, a na 
środku ekranu słodka reprymenda: „You're too 
slow” —jeszcze możesz spróbować, ale uwa- 
żaj, żebyś nie musiał szukać innej pracy. 


Teraz w duchu postanawiasz: spokojnie, 
bez nerwów, od domu do domu. Zaczyna- 
my... Pierwszy kosz... dobrze... odnosimy... z 
powrotem... Och! Pisk opon i... oczom Twoim 
ukazuje się krótka notatka na czarnym tle — 
... Trashman... zostawił żonę i troje dzieci oraz 
100 zdobytych dotychczas punktów... Dobrze, 
że to tylko gra. 

Zauważyłeś zapewne, iż po bezbłędnym 
obsłużeniu posesji, gospodarz pojawia się w 
drzwiach i proponuje Ci napiwek lub zarobie- 
nie czegoś „na boku”. Warto skorzystać. Kilka 
sekund spędzisz w budynku, ale bonus i tak 
się powiększy. 

Na pewno po kilku próbach opróżnisz pięć 
koszy na Montague Road. Zostaniesz wtedy 
przeniesiony na Pulteney Road, ulicę dłuższą 
i trudniejszą do przejścia, ale zamieszkałą 
przez hojniejszych londyńczyków. Mają oni 
bardziej rozbudowane posiadłości, ich dzie- 
ci bardzo lubią jeździć na rowerach, a pieski 
podwórzowe dbają o ogródki. Mimo to powi- 
nieneś również tam ukończyć swą pracę w wy- 
znaczonym czasie i zostać przeniesionym na 
jedną z głównych ulic dzielnicy — Cro... Nie! 
Przekonaj się sam, ile ulic jest w Londynie. 

Gra ma jeszcze jedną zaletę. Nawet gdy 
Twoja znajomość języka angielskiego nie jest 
doskonała, na pewno ubawią Cię komenta- 
rze pojawiające się na ekranie. Dowiesz się 
na przykład o człowieku, który kazał wyrzucić 
komputer swego syna oraz o nowym modelu 
Spectrum 4 MB. Warto zagrać! 

Firma: New Generation Software 

Komputer: ZX Spectrum 48/+, 

Commodore 64/128, 

Amstrad/Schneider. 
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Na pewno oglądałeś nieraz w telewi- 
zji lub z trybun zawody hippiczne. Biorą w nich 
udział najlepsi jeźdźcy w kraju. Jeśli jednak i ty 
chcesz spróbować swych sił w tej dyscyplinie 
sportu, zagraj w Show Jumping. 

Jesteś dżokejem biorącym udział w corocz- 
nie organizowanych zawodach jeździeckich. Do 
przejechania masz tor składający się z pięciu do 
piętnastu przeszkód. Są to murki, rowy z wodą, 
poprzeczki na stojakach, poziome żerdzie, becz- 
ki. Za strącenie przeszkody otrzymujesz odpo- 
wiednią ilość punktów karnych. Gdy ilość punktów 
karnych przekroczy dwadzieścia zostajesz zdys- 
kwalifikowany. Dyskwalifikacja następuje również, 
gdy twój koń odmówi posłuszeństwa trzy razy. 

W zachowaniu odpowiedniej kolejności prze- 
skakiwania pomogą Ci litery umieszczone przy 
każdej przeszkodzie i jeździec na koniu w górnej 
części ekranu pokazujący kierunek skoku przez 
przeszkodę. 

Ilość punktów karnych przedstawiona jest w le- 
wym górnym rogu ekranu, a czas w prawym. 
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Przed rozpoczęciem gry możesz wybrać ilość 
graczy oraz konia, na którym chcesz jechać. Gdy 
wybierzesz, zobaczysz plan toru, na którym są 
zaznaczone kierunki pokonywania przeszkód, 
start i meta. Poziom trudności gry wybierasz na 
początku. Wybór jest prosty: hard (trudno) lub 
easy (łatwo). Sterowanie: Kempston joystick, 
Sinclair joystick, keyboard. 

W grze może brać udział do ośmiu graczy, któ- 
rzy mają do wyboru po jednym z ośmiu koni. Po 
zakończeniu konkurencji wyświetlana jest tablica 
wyników wraz z czasami przejazdów i ilościami 
punktów karnych (foul) dla każdego zawodnika. 

Grę cechuje dokładna, staranna grafika i nie- 
złe, choć mało zróżnicowane efekty dźwiękowe. 
W sumie jest to ciekawa i dobra zabawa do wy- 
korzystania w rodzinnym gronie podczas długich, 
nudnych wieczorów. 

Autor: Eliot Gay 

Komputer: ZX Spectrum 48/+, Commodore 
64/128, Amstrad/Schneider. 
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Małgorzata Łącka lat 9, uczennica Il klasy Szkoły 
Podstawowej nr 164 w Warszawie. Gra (na Spec- 
trum 48) najczęściej z bratem, Grzegorzem, lecz jak 
twierdzą zgodnie oboje, jest od niego znacznie lep- 
sza. Hobby: książki. 


Marcin Jarek lat 12, uczeń ki Vb Szkoły Pod- 
stawowej nr 57 w Warszawie jest bardzo dobrym 
uczniem. Lubi grać na swoim Spectrum Plus. Ulu- 
biona gra: TURBO. Hobby: sport, w szczególności 
jazda na rowerze. 


$.0.8. 


Szukam instrukcji do gry TIGERS IN THE SNOW na 
ATARI z magnetofonem oraz instrukcji do SPY VS SPY 
Il na ten komputer. Pragnę wymienić oprogramowanie. 
Odstąpię instrukcję SILENT SERVICE. 

Piotr Kołuda 


ul. Limanowskiego 154 m 
43 91-032 Łódź 


Mam komputer ATARI 800 XE. Proszę o podanie nie- 

AES Ę gier: PRELIMINARY MOUNTY, SHA- 
MUS, Z 

Wojciech Franaszczuk 

ul. Wrocławska 19 

55-050 Sobótka 


Proszę o plan ATARI i nieśmiertelność do gry THE 
GREMLINS na ATARI. 

Krzysztof Zedlewski 

ul. Brzozowa 13 

82-200 Malbork 


Jak dojść w grobowcu do drzwi z podkową, butem i trąb- 

ki Jak uwolnić księżniczkę w grze ZORRO w wersji na 

ATARI? Nie mogę sobie także poradzić z kodem w grze 

PHARAOHS CURSE. Poszukuję też dokładnego opisu 
do gry SWAT. 

Andrzej Zasłonka 

ul. Piotrkowska 182 m 138 

90-368 Łódź 

telefon 36-36-36 


Zwracam się o pomoc do czytelników szukam mapy do 

gry ICE PLACE, a także nieśmiertelności do gier: BOUL- 

DER DASH III, LAZY JONES i BEACH HEAD na Com- 
modore 64. 

Sebastian Cyrson 

ul. PCK 5 m 86 

81-621 Gdynia 


Nie wiem, jak przejść planszę „g” w grze BOULDER 

DASH. W grze GREEN BERET Doszukuję nieśmiertel- 
ności. Mam komputer ATARI 130 XE. 

Wojciech Glanowski 

Os. Skalska 2 m 22 

32-340 Wolbrom 


Moją ulubioną grą jest KILLER GORILLA. Niestety, nie 

wiem, jak przejść trzecią planszę — nie umiem wsko- 
czyć na windę. 

Maciej Zieliński 

ul. M. Nowotki 44 m 112 

32-300 Olkusz 


Jak uzyskać nieśmiertelność w grach: BRUCE LEE, 

MONTEZUMAS REV., CRYSTAL RAIDER w wersji ka- 
setowej na ATARI 800 XL? 

Patryk Zawadowicz 

ul. Matejki 40a m 2 

72-600 Świnoujście 


Poszukuję instrukcji do gry SILENT SERVICE. W zamian 
służę opisami do gry F-15 i KENNEDY APPROACH. 

Jakub Lercel 

ul. Dobrego Pasterza 125 m 67 

31-416 Kraków 


Pomóżcie! Kto mi przyśle A: do gier: STORM, BILBO, 
PHANTOM na komputer ATAR 

Daniel Chojecki 

ul. Lekarska 16 m 16 

00-610 Warszawa 


Proszę o pomoc w grze RAMBO. Umiem zebrać wszyst- 
kie rodzaje broni, a dalej nie wiem, co robić. 

Fryderyk Badura 

ul. Dworcowa 5 m 41 

44-200 Rybnik 


Mam komputer ATARI 800 XL. Proszę o pomoc w grach 
NEW YORK CITY i KING OF RING. 

Radosław Forma 

ul. Kościuszki 19 m 80 

41-300 Dąbrowa Górnicza 


W grze APOLLO MISSION dochodzę do drugiej plan- 

szy nie umiem przejść dalej. Proszę także o adres firmy 

wysyłającej programy pocztą po niskich cenach. Mam 
Commodore +4. 

Artur Szubert 

ul. Raciborska 2 

47-480 Pietrowice Wielkie 


Może ktoś mi pomoże, nie wiem jak grać w grę EXOR- 

CIST oraz jak przejść planszę w trzecim etapie gry 
CAVE FIGHTER, obie w wersji na C-16. 

Jarosław Wierny 

ul. Zubrzyckiego 25b m 207 

45-263 Opole 
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NASTĘPNY KROK 


Od dawna już nie mieliśmy 
w „Następnym Kroku” okazji 
programować. Zebyście przy- 
padkiem nie nabrali podej- 
rzeń, że informatyka to dzie- 
dzina bardziej teoretyczna niż 
praktyczna, dziś zadanie prak- 
tyczne — będziemy obliczać 
wartość wielomianu. 


Żeby wszyscy mieli równe szanse zaczynamy od 
podstaw. Wielomian jest to funkcja zapisana nastę- 
pującym ogólnym wzorem: 

a,X" +a, „X"'+a_„X"* +... + a,X*-A,X+a, 

Liczba n jest stopniem wielomianu. Wielomian 
stopnia n ma n + 1 współczynników (liczby a, a ,..... 
a,, a,, a,). Każdy z tych współczynników jest pomno- 
żony przez odpowiednią potęgę zmiennej x. Oczywi- 
ście podany wzór jest to ogólny wzór na wielomian. 
Konkretny wielomian otrzymamy ustalając stopień, 
np. n=4 i podając współczynniki (4 + 1=5 liczb) a, do 
a,. Np dla a, = 7, a,=-2, a, = 1, a,=2, a, = 11. otrzymu- 
jemy następujący wielomian stopnia czwartego: 

7x*-2X3 + x? + 2x + 11 

Dodajmy jeszcze, że wielomian stopnia pierw- 
szego, to zwykła funkcja liniowa (jej wykresem jest 
prosta), a stopnia drugiego to trójmian kwadratowy, 
prezentowany w szkole średniej (jego wykresem jest 
parabola). 

Oczywiście do konkretnego wielomianu możemy 
wstawiać różne wartości zmiennej x. Otrzymamy 
wtedy różne wartości funkcji. Obliczenie tych warto- 
ści gdy znamy wartości współczynników oraz zmien- 
nej x nie jest zadaniem wymagającym wiele myśle- 
nia. Trzeba po prostu wykonać odpowiednie operacje 
potęgowania, mnożenia potęg x przez współczynniki 
oraz dodawania otrzymanych iloczynów. 

Proste, prawda? Możemy już chyba z łatwością 
pisać program, który zrobi to za nas. Ale przecież miało 
być od podstaw, więc jak mamy zapisać wielomian w 
pamięci komputera? Stopień zapiszemy w zmiennej, 
najlepiej nazwać ją n, zaś do zapisania współczynni- 
ków użyjemy tablicy jednowymiarowej, mającej n+1 
elementów — liczb rzeczywistych. W jednym elemen- 
cie zapiszemy jeden współczynnik: w A(0) - a,, w A(1) - 
a,, itd. W BASIC-u deklaracja potrzebnej tablicy mogła 
by wyglądać: 

DIM A(N) 

W Pascalu zaś: 

A:arrary[0..n] of real; 

Niestety jednak tak zadeklarować tablicy nie może- 
my — jej wymiar nie może być zmienną, nie pozwalają 
na to reguły języka programowania (w Pascalu taka 
konstrukcja jest w ogóle niedozwolona, w BASIC-u nie 
może wystąpić wewnątrz pętli). Co więc zrobić? Dekla- 
rować: array[0...5] gdy chcemy liczyć wielomian stopnia 
5 i zmieniać deklarację na array 0...100 gdy n = 100? To 
bez sensu — dla każdej zmiany stopnia trzeba nowy 
program! 

Zrobimy inaczej, zadeklarujemy tablicę tak długą, 
aby zmieścił się w niej każdy z przewidywanych wielo- 
mianów, a następnie dla konkretnego n będziemy wy- 
korzystywać początkowy fragment, czyli elementy od 
A(0) do A(n). 

Jeśli tablica A zawiera współczynniki wielomianu, 
to możemy obliczyć jego wartość w punkcie x jedną, 
prostą pętlą: 

30 W=0 

40 FOR I=0 TON 
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50 W=W+A(l)*XM 
60 NEXT I 


70 REM Tu W zawiera obliczoną wartość wielomia- 
nu. 

Spróbujmy teraz zapisać to samo w Pascalu. Ponie- 
waż jednak nie ma w nim operacji potęgowania musi- 
my zrobić to nieco inaczej. Zauważmy, że po obliczeniu 
wartości x', aby obliczyć x*' nie potrzebujemy wcale 
używać potęgowania, wystarczy mnożenie x'*x. Ina- 
czej mówiąc, zaczniemy od znanej wartości x (pamię- 
tamy, że x=x'), x? uzyskamy jako x'*x, x3=x7*x, X*=x5*X, 
itd. Wykorzystamy to w poniższym programie. Zmienna 
xp będzie zawierała wartości kolejnych potęg x: 

program wielomian (input, output); 

fprogram obliczania wartości wielomianu) 

var 

x,xp,w: real; 

n,i  :integer; 

A:array [0.100] of real; 

begin 

writeln ('Podaj stopień n'); 

readln(n); 

(generacja współczynników wielomianu zamiast ich 
wczytywania — przyspieszy testowanie programu) 

for i: = Oto ndo ATi]: = i; 

writeln ('Podaj x'); 

readln (x); 

(zaczynamy obliczenia) 

w:=AT[0], 

xp:= 1; 

for i: = 1 to n do 

begin 


Xp: = xp*X; 
W: =W + ATi]*xp; 
end; 


writeln ('Dla x=', x,' wartość wielomianu wynosi',w) 

end. 

Mamy dwa różne programy, wykorzystujące dwie 
metody obliczenia tej samej wartości. Jak porównać 
szybkość ich działania? Oczywiście najprościej zrobi- 
my to uruchamiając każdy z nich i mierząc czas wyko- 
nania. Trzeba jednak pamiętać o kilku istotnych spra- 
wach: 

— oba programy muszą być napisane w tym samym 
języku i ttumaczone tym samym kompilatorem (in- 
terpreterem) — chodzi nam o porównanie szybkości 
programów a nie translatorów; 

— należy mierzyć tylko czas wykonywania obliczeń — 
bez wczytywania danych itd.; 

— drobne różnice mogą być trudne do uchwycenia 
przy pomiarze czasu zegarkiem czy stoperem, wte- 
dy fragment programu wykonujący obliczenia moż- 
na umieścić we wnętrzu pętli, która wykonuje się 
np. 10 lub 100 razy, odpowiednio zwielokratniając 
różnicę i ułatwiając pomiar. Zachęcam do przepisa- 
nia drugiej metody w BASIC-u i wykonania prób. Od 
razu zdradzę też swoje wyniki: posługiwałem sie in- 
terpreterem BASIC-a na1BM PC, przy jednokrotnym 
wykonaniu obliczeń dla wielomianu stopnia 100 róż- 
nica była niewidoczna gołym okiem. Przy wykonaniu 
obliczeń 100 razy, bez użycia sekundnika widać, że 
drugi z badanych programów jest szybszy. Bardzo 
się ucieszyłem tym rezultatem, gdyż jest on zgodny 
z oczekiwaniami. Drugi program powinien być szyb- 


szy. Skoro tak, to spróbujmy zastanowić się, gdzie 
tkwi źródło tej większej szybkości. Odpowiedź jest 
prosta: zmieniliśmy algorytm. Krótko mówiąc, wró- 
ciliśmy do wyniku naszych rozważań z przed kilku 
miesięcy (Bajtek 4 i 5/87) — podstawowym źródłem 
efektywności programu jest dobry algorytm. Jednak 
aby móc mówić o dobrych czy złych algorytmach 
musimy mieć możliwość ich porównywania. 

Powszechnie przyjętym kryterium jest ilość podsta- 
wowych operacji, które algorytm wykonuje aby znaleźć 
rozwiązanie. W przypadku obliczania wartości funkcji 
tymi podstawowymi operacjami będą oczywiście dzia- 
łania arytmetyczne. 

Pierwszy z naszych algorytmów wymaga dla obli- 
czenia wartości wielomianu stopnia n, wykonania n + 
1 potęgowań, n + 1 mnożeń i n + 1 dodawań. Drugie- 
mu wystarczy 2n mnożeń i n dodawań. Zysk wynika 
ze znacznej różnicy czasu wykonania potęgowania i 
mnożenia (oczywiście na korzyść mnożenia), i wynosi: 

n”(czas potęgowania-czas mnożenia) 

Chociaż różnica może wydawać się nieco teoretycz- 
na, to jednak wcale taka nie jest. Wielomiany tak często 
występują w praktycznych zastosowaniach, że nawet 
niewielki wzrost szybkości obliczeń daje efekt prak- 
tyczny. Efekt ten nie jest widoczny przy jednorazowym 
wykonaniu zadania, ale staje się bardzo znaczny jeśli 
wartość wielomianu trzeba obliczyć wiele tysięcy razy 
w jednym programie. Uzasadnionym staje się więc py- 
tanie: czy nie można by liczyć jeszcze szybciej? 

Można, a algorytm który to umożliwia stanie się 
oczywisty, gdy zapiszemy wielomian w inny sposób. 
Zacznijmy od przykładu dla n=3: 

a;X*+a,X*+A,X+ a,=((a;X+a,)X+a,)X+a, 

Proszę wymnożyć prawą stronę i przekonać się, że 
równość rzeczywiście zachodzi. Oczywiście w ten sam 
sposób można zapisać wzór ogólny: 

(((...(a,X + a, ,)X+a, „)X+...+a,)X+a,)X+a, 

Nie będę przeprowadzał dowodu poprawności ta- 
kiego zapisu, gdyż jest on powszechnie znany mate- 
matykom pod nazwą schematu Homera (od nazwiska 
matematyka, który opublikował go w 1819 r.). 

Przejdźmy od razu do zastosowania naszej nowej 
wiedzy w praktyce. Tym razem postąpimy jak rasowi 
projektanci i zamiast zaczynać od programowania spró- 
bujemy policzyć ile operacji musi wykonać algorytm li- 
czący wg tego schematu aby otrzymać wynik. Rachu- 
nek jest bardzo prosty, wystarczy się uważnie przyjrzeć 
wzorom. Mamy do wykonania n mnożeń przez wartość 
zmiennej x oraz n dodawań — spróbujcie na początek 
prześledzić to na podanym przykładzie, dla n=3. 

N mnożeń i n dodawań to znacznie lepiej niż po- 
przednio. Najlepiej jak można to zrobić. Jak się bowiem 
okazuje udało się udowodnić, że nie można obliczyć 
wartości wielomianu w jednym punkcie używając mniej- 
szej liczby operacji arytmetycznych. Możemy więc nie 
łamać sobie dłużej głowy i ze spokojnym sumieniem 
napisać ostateczną wersję programu obliczającego 
wartość wielomianu. 

Proponuję jednak odłożyć to na następny miesiąc, 
bo dziś nie sam program był najważniejszy, lecz prak- 
tyczne pokazanie, że o jakości programów nie decydu- 
je sama biegłość w pisaniu instrukcji języka programo- 
wania, lecz również, (a może nawet przede wszystkim) 
umiejętność wymyślenia lub dobrania najlepszego al- 
gorytmu. Ważne też było pokazanie ciekawego algo- 
rytmu. Zabrakło natomiast miejsca na rozwinięcie kilku 
godnych uwagi szczegółów technicznych, dotyczących 
programowania, które pojawiły się po drodze, dlatego 
za miesiąc wrócimy do programowania algorytmu Ho- 
mera. 


Andrzej Pilaszek 


*) Może się np. zdarzyć, że dla pewnych danych je- 
den z dwu programów jest szybszy, a dla innych 
danych szybszy będzie drugi. 

**) Oczywiście w poważnej pracy potrzebny byłby 
tu jakiś dowód, że tak jest naprawdę dla każde- 
go n. Takie dowody istnieją, nie będę ich cyto- 
wał, aby nie zmieniać tego artykułu w teoretycz- 
ną rozprawę 


rytemy 


WSZYSTKO 
O SCALAKACH 


Włączając ulubione Spectrum czy 
Atari z pewnością zastanawialiście 
się nie raz, jak powstaje tak skompli- 
kowane urządzenie, co kryje się pod 
jego obudową i jak ono w ogóle funk- 
cjonuje. Tym razem zaprezentujemy 
kilka książek poświęconych układom 
scalonym, czyli elementom, bez któ- 
rych nie byłoby możliwe zbudowanie 
mikrokomputera. 


Pierwsza z nich, to „Układy scalone w pytaniach i 
odpowiedziach” R. Ćwirko, M. Ruska i W. Marciniaka 
wydane przez WNT. Znajdziemy w niej bogate informa- 
cje na temat stosowanych w elektronice procesów wy- 
twarzania oraz różnych typów układów scalonych i spo- 
sobów ich wykorzystania. Czytelnik ma okazję zapoznać 
się z nowoczesnymi układami scalonymi produkowany- 
mi w technologii MOS, PMOS, NMOS, lub CMOS, roz- 
szyfrować znaczenie terminów: układ scalony bipolarny 
USB czy też układy hybrydowe. 

Czytelników „Bajtka” na pewno szczególnie zaintere- 
sują układy cyfrowe, które są cegiełkami służącymi do 
budowy mikrokomputera. W dalszej części książki au- 
torzy zajmują się właśnie podstawami algebry Boole'a i 
układami cyfrowymi TTL i TTLS, jak bramki, przerzutniki, 
liczniki czy rejestry oraz pamięciami półprzewodnikowy- 
mi RAM, PRÓM i EPROM. 

Bliższe informacje o mikroprocesorach można zna- 
leźć w książce „Mikroprocesor w pytaniach i odpo- 
wiedziach” K. Sachy i A. Rydzewskiego, którą szcze- 
gółowo przedstawiliśmy w numerze 8/87. Obie książki 
zredagowane są w bardzo przystępnej formie pytań i 
odpowiedzi, ilustrowane licznymi rysunkami schematami 
i wykresami. 

Trzecią pozycją, którą warto przeczytać, jest obszer- 
ne opracowanie Antoniego Niederlińskiego „Mikropro- 
cesory, mikrokomputery, mikrosystemy” wydane 
przez Wydawnictwa Szkolne i Pedagogiczne. Książka 
ta zawiera dużo wiadomości o mikrosystemach i może 
okazać się przydatna różnym grupom odbiorców. Szcze- 
gólnie dokładnie potraktowano w niej zagadnienie mikro 
— i makroarchitektury systemu mikrokomputerowego. 
Korzystanie z książki i zrozumienie trudnej tematyki jest 
możliwe nawet dla czytelnika mającego niewielką wie- 
dzę o elektronice. Pomagają w tym m.in. starannie opra- 
cowane ilustracje. 

Autor przyjął zasadę omawiania od podstaw pojęć 
z dziedziny informacji cyfrowej. Po przebrnięciu przez 
rozdziały ukazujące zasadę funkcjonowania rejestru, 
przerzutnika czy licznika mamy już odpowiednie przygo- 
towanie, by zająć się architekturą mikroprocesora i mi- 
krokomputera lub budową i działaniem układów wejścia 
— wyjścia. W drugiej części autor proponuje czytelnikowi 
rozpoczęcie samodzielnego programowania. Wstępem 
do poznania reguł tej trudnej sztuki są ciekawe rozdziały 
o strukturze i konstrukcji algorytmu oraz o asemblerze 
mikroprocesora 8880 i Basicu. Bardzo cenna wiado- 
mość znajduje się w części opisującej sposób wymiany 
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informacji między elementami mikrosystemu. Omawiane 
tu różne protokoły komunikacyjne będą użyteczne dla 
tych, którzy spróbują podłączyć nietypowe urządzenie 
zewnętrzne do swojego komputera. 

Projektantom oraz studentom informatyki poleciłoym 
wydaną przez WNT książkę niemieckiego autora Rudo- 
ifa Hedtke „Systemy mikroprocesorowe”. Książka zaj- 
muje się niezawodnością sprzętu, sposobami określania 
i przewidywania na etapie projektowania intensywności 
uszkodzeń elementów mikrokomputera. Pokazane są w 
niej także metody testowania pojedynczych podzespo- 
łów, a także całego systemu oraz urządzeń peryferyj- 
nych i pamięci. 

Duże zainteresowanie i wiele pytań o sposób progra- 
mowania w asemblerze świadczy o ogromnej popular- 
ności tego języka. Zdobycie literatury dotyczącej mikro- 
procesora Z-80 nie stanowi w chwili obecnej większego 
problemu. Listę rozkazów i podstawowe wiadomości o 
posługiwaniu się językiem maszynowym można zna- 
leźć w instrukcjach obsługi Spectrum, zeszytach wy- 
dawanych przez Stronnictwo Demokratyczne, książce 
„Mikroprocesor w pytaniach i odpowiedziach”, skrypcie 
SOETO „Oprogramowanie podstawowe ZX-Spectrum 
— .DEVPAQĆ 3 MONS3)” lub omówionej w poprzednim 
numerze Bajtka książce „Mikroprocesor Z-80”. Dziwi 
natomiast zaniedbanie licznego grona użytkowników 
komputerów z rodziny Commodore Apple, Laser, Acorn 
czy Atari. Listę rozkazów bardzo rozpowszechnionego 
mikroprocesora 6502 znajdziemy tylko w „Atari BASICU” 
W. Miguta lub nielicznych artykułach np. w „Kompute- 
rze”. Dużego zapotrzebowania na literaturę o 6502 na 
pewno nie zaspokoi książka Jana Ruszczyca „Asem- 
bler 6502”, wydana w niewielkim nakładzie 5000 egz. 
przez SOETO. Jest to dobrze napisany podręcznik pro- 
gramowania w asemblerze, zawierający obok opisu roz- 
kazów i trybów adresowania wiele przykładów procedur 
i ćwiczenia do samodzielnego rozwiązania. Technika 
programowania została omówiona w łatwy do zrozumie- 
nia sposób. Podprogramy skonfrontowano z odpowiada- 
jącymi im strukturami Basica, co bardzo pomaga w ich 
analizie. Ze względu na dużą popularność Atari dołączo- 
no także rozdział poświęcony układom ANTIC i GITA, 
a także wiele uwag, sposobie tworzenia obrazu, wyko- 
rzystania grafiki graczy i pocisków oraz o przerwaniach. 
Książka ta uczy racjonalnego posługiwania się asemble- 
rem, który jest językiem pozwalającym „lepiej zrozumieć 
architekturę mikrokomputera i wewnętrzne mechanizmy 
działania” oraz „głębiej wniknąć w strukturę języków wy- 
sokiego poziomu i efektywniej w nich programować”. 


(i.j) 


Robert Cwirko, Mirosław Rusek, Wiesław Marciniak 
— „Układy scalone w pytaniach i odpowiedziach”, 
WNT, Warszawa 1987. Wyd. II. Nakład 60000 egz. 
Cena 590 zł. 

Antoni Niederliński — „Mikroprocesory, mikrokom- 
putery, mikrosystemy” — Wydawnictwa Szkolne i 
Pedagogiczne, Warszawa 1987, Wyd. I. Nakład 10000 
egz. Cena 657 zł. 

Rolf Hedtke — „Systemy mikroprocesorowe” — 
przełożył Andrzej Dworak. WNT, Warszawa 1987, 
Wyd. I. Nakład 70 000 egz. Cena 500 zł. Jan Ruszczyć 
— „Asembler 6502” — SOETO, Warszawa 1987, Wyd. 
I, Nakład 5000 egz. Cena 910 zł. 
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Walka o mózgi trwa. Po- 
chodzący z Tajwanu Steve 
S. Chen opuścił największą 
na świecie firmę superkom- 
puterowa Craya. by wkrót- 
ce dostać się pod skrzydła 
głównego giganta od _pro- 
dukcji masowej — IBM. 


„Big Blue” gotowy jest zainwestować 
miliony, by stworzyć za kilka lat bardziej 
powszechny, komercyjny superkomputer 
najwyższej generacli, oparty na wielu rów- 
noległych procesorach i wykorzystujący 
połączenia świetlne. Gzy niezwykły talent 
Che- na, przy wsparciu pieniędzy i eksper- 
tów IBM. rozwikła zagadkę i to w ciągu 5 
lat9 — zastanawia się tygodnik DER SPIE- 
GIEL 

Na każdym z zebraniu akcjonariuszy 
spółki Cray Research stawiane jest pyta- 
nie-, co stanie się z firmą jeśli jej gtówny 
udziałowiec Seymour Cray dostanie się 
np. pod koła ciężarówki 61-letni twórca 
najszybszego komputera na świecie opo- 
wiada zwykle, że również jego przeraża 
taka perspektywa 

Przez kilka ostatnich lat istniało zabez- 
pieczenie dla „ojca chrzestnego” branży 
superkomputerowej i jego firmy w Minne- 
apo- lis; w amerykańskim stanie Minne- 
sota Od 1979 roku poza Cray'em również 
Steve S. Chen, „syn chrzestny” w hierar- 
chii elektronicznych czaiodzie|ów, tworzyt 
dzieła sztuki z chipów, tchnąć w nie życie. 
Jednakże we wrześniu ubiegłego roku 
geniusz wyrwał się z zaprzęgu. Zawie- 
dziony polityką firmy, Chen pokazał plecy 
przedsiębiorstwu Cray Research. Odejście 
43-letniego twórcy niezwykłych konstrukcji 
wstrząsnęło najwybitniejszą na świecie 
firmą produkującą superkomputery. Akcje 
Cray'a gwałtownie spadły, tracąc caty swój 
niedawny blask 

Do końca marca IBM przypieczętował 
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umowę z Chenem, która ma go przywiązać 
na stałe do „Big Blue”. Wieści nadchodzą- 
ce z centrali IBM w Armonk. w stanie Nowy 
Jork, mówią, ze ten największy na świecie 
producent komputerów wchodzi do powsta- 
jącej właśnie spółki Chena „Super- compu- 
ter System Inc.” w Fauciaire, w amerykań- 
skim stanie Wisconsin W zamian za pakiet 
udziałów o nieznanych jeszcze rozmiarach 
IBM chce sobie zapewnić wgląd w tajem- 
nice kuchni superkomputerowych magów. 
Doborowa grupa ekspertów ze stajni IBM 
ma — zgodnie z zawieranym porozumie- 
niem — współpracować z pochodzącym z 
Tajwanu twórcą superkomputerów 


W ciągu 5 lat ze związku między po- 
tężnym, opanowującym rynki, słoniem 
a sprytną myszką winien narodzić się 
pierwszy, w pełni dojrzały produkt no- 
wej serii — komputer najwyższej ge- 
neracji, „pożeracz liczb”, o szybkości 
kilkuset razy większej niż obecny rekor- 
dzista świata „Numbercruncher” z wy- 
twórni Cray'a. o nazwie Cray 2. 


Oto recepta Chena na planowany su- 
perkomputer: 64 wysoko wydajne pro- 
cesory winny wspólnie i równocześnie 
zajmować się programem, ultraszybkie po- 
łączenia świetlne mają zastąpić klasyczne 
przewodowe połączenia. 

Maszynę działającą zgodnie z tymi za- 
sadami chciał Chen opracować również 
dla byłego pracodawcy — Cray'a, któremu 
jednakże koncepcja ta wydała się tak ry- 
zykowna (koszty badań szacowano na 100 
milionów dolarów), że wstrzymał projekt, 
określany w skrócie MP („Muiiiple Proces- 
sor”). Dla Chena było to wystarczającym 
powodem, by opuścić Cray'a. 

Fakt. iż konserwatywny kolos, jakim 
jest IBM, zdecydował się na zakup talentu 
Chena, zaskoczył ekspertów. Wraz z tym 
czoło wym konstruktorem, IBM decydu- 
je się na dwa równocześnie wielkie skoki 
w nieznane — na przejście w wąski krąg 
twórco.-/ maszyn typu „Numbercruncher” 
i na wkroczenie w ryzykowną dziedzinę 
komputerowej „architektury równoległej”. 


Od czasu, gdy w 1976 roku Seymour 
Ciay ustanowił po raz pierwszy standard 
w dziedzinie superkomputerów w postaci 
maszyny obliczeniowej Cray 1, IBM był 
na tym rynku, wyznaczanym odtąd przez 
Craya, jedynie stojącym na uboczu obser- 
watorem. Jeszcze w 1987 roku, gdy IBM 
zaprezentował własną maszynę o naj- 
wyższej wydajności, a mianowicie model 
„3090—600 FVF” koncern podtrzymywał 
podstawowe twierdzenie, że komputer o 
strukturze równoległej dla ceiow komercyj- 
nych byłby zbyt kosztowną i zbyt ryzykow- 
ną technicznie przygodą. 

IBM musiała więc z pewnością przetra- 
wić na nowo całą sprawę, aby przywrócić 
do łask postulat schematu równoległego 
— stwierdza Denny Hillis, enfant terrible 
wśród konstruktorów superkomputerów. 
Decyzja „Big Blue” w sprawie Chena ozna- 
cza zdaniem Hillisa olbrzymi krok naprzód 
w zakresie badań nad strukturą równoległą 
„ — Wszyscy muszą teraz bardzo przyspie- 
szyć, gnani strachem przed IBM. 

Dotychczas obowiązująca zasada ma- 
tematyczna, wynaleziona w latach czter- 
dziestych przez amerykańskiego mate- 
matyka Johna von Neumanna, zgodnie z 
którą jeden centralny procesor opracowuje 
kolejno, krok po kroku, informacje zawarte 
w pamięci roboczej — wyczerpała możli- 
wości twórcze. Seymour Cray i jego prawa 
ręka Chen osiągnęli w swych arcydziełach 
X-MP i Cray-2 granice zawartych w niżej 
możliwo sci. 

W ostatnim dziale Chena, nazwanym 
Cray X-MP, |uż cztery procesory zajmują 
się prowadzeniem obliczeń. Na łyle, na 
ile pozwala program, procesory te dzielą 
między siebie czynności logiczne i dzięki 
temu osiągają rekord w wysokości ponad 
miliarda operacji zmiennoprzecinkowych 
na sekundę. Maszyny o takiej wydajności 
oferuje jak do tej pory jedynie pięciu pro- 
ducentów — poza Crayem występują na 
rynku jedynie fu ma Control Data i Irzy fir- 
my japońskie. 


Dzięki technice czteroprocesorowej 
firma Cray, która dotąd pokrywała dwie 


trzecie zapotrzebowania na super kom- 
putery na rynku światowym, wkroczyła 
sama na pierwszy stopień „architektury 
równoległej”. Bardziej niż ostrożne kro- 
ki prowadzące stamtąd do poziomu 8, 
a następnie 16 procesorów wydały się 
jednak Cray owi i tak na razie zbyt ry- 
zykowne. 


Na — jak dotąd — najbardziej radykal- 
ny odwrót od zasady klasycznej odważył 
się przed niespełna dwoma laty, mający 
wówczas 30 lat, konstruktur komputerów 
Hillis. W 1983 roku założył on w Canbridge 
w stanie Massachucsetts firmę „Thinkung 
Machinę Corp”, a następnie w 1986 roku 
przedstawił własny komputer równoległy 
„Connection Machinę”. Na czarnej, mato 
wej kostce obliczeniowej 65 536 proceso- 
rów przetrawiało w nim wspólnie pokrojony 
na kawałeczki program. 

Za około jednej czwartej ceny kompute- 
rów Cray'a, z których każdy kosztuje dobre 
12 milionów dolarów, otrzymuje się dzięki 
lemu urządzenie o porównywanie wyso- 
kich osiągach. Jak dotąd system podzia- 
łu pracy między procesorami nadaje się 
oczywiście ledynie do niewielu programów 
specjalnych. 

Chen natomiast chce wynaleźć opartą 
na systemie równoczesnym super-maszy- 
nę obliczeniową „na codzienny użytek”, 
nie zaś — maszynę wyścigową do poko- 
nywania odcinków próbnych. Tego rodzaju 
zada nie wymaga jednak nie tylko ducha 
pionierskiego, ale i dobrych pleców, takich, 
jakie może zapewnić koncern IBM. 

Dlaczego niektóre problemy rozwią- 
zywane są przez „komputery paralelne” 
setki razy szybciej, inne zaś wymagają 
tyle samo czasu, co maszyny zbudowane 
zgodnie z zasadą von Neumanna? — Tak 
oto eksper; z IBM Abraham Poled sformu- 
łował jedną z zagadek systemu równole- 
głego. Jeszcze inny dylemat, odnoszący 
się do programowania, brzmi: co należy 
czynić w przypadku komputerów systemu 
równoległego, jeśli wiele procesorów wy- 
woła w tym samym czasie te same infor- 
macje z pamięci? 

Autorów tego rodzaju wątpliwości ostro 
gani Hillis, który mówi o „filozoficznym baj- 
durzeniu” ludzi bez odwagi. Wraz z wejś 
ciem Chena — ma nadzieję ten szyderca 
— całe gadanie się zakończy: węzły pro- 
blemów przetnie się najlepiej demonstru- 
jąc kilka logicznych dowodów. 


opr. (f) 


Te zapałki można bez obawy dać 
do zabawy nawet małemu dziecku. 
Każdy, kto przy ich pomocy Spróbuje 
rozniecić ogień, odkryje ze zdziwie- 
niem, że w pudełeczku ukryto kalkula- 
torek. Być może przemyślny i dowcip- 
ny konstruktor w ten właśnie sposób 
pragnął uchronić nas przed skutkami 
beztroskich igraszek pozostawionych 
w domu bez opieki maluchów. Poza 
tym zawsze warto mieć pod ręką pro- 
ste urządzenie, które realizuje czter 
podstawowe działania. (i j j 
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MATCH CALCULATOR 


Kiedy 8 lat temu odebrałem pierw- 
szy całkowicie zredagowany i na- 
pisany przy pomocy osobistego 
komputera list mego amerykańskie- 
go przyjaciela, miałem wrażenie ob- 
cowania z czymś nadzwyczajnym, 
wręcz sensacyjnym. Dziś nawet w 
Polsce specjalnie nie szokuje arkusz 
papieru zapełniony symbolami, zna- 
kami, czy rysunkami wypełzającymi 
z urządzenia, które zwykliśmy nazy- 
wać drukarką. Ale żeby były na nim 
kopie fotografii? 


WCZYTYWANE Z RĘKI 


W 1984 roku pojawiły się w Stanach Zjednoczonych 
powszechnie dostępne oprogramowania umożliwiają- 
ce manipulację tekstem i wtaczanie w jego ustępy zre- 
produko- wanych zdjęć, szkiców, czy nawet pozosta- 
wionych w pamięci systemu obrazów. Pozostawionych 
dzięki współpracy z przyłączonymi do mikrokomputera 
specjalnymi scan- nerami przetwarzającymi całe stro- 
nice książek. Dzięki tomu wszystkiemu można się było 
stać właścicielem domowego kserografu i to tak dosko- 
nałego, iż pozwalającego na dowolną obróbkę wpro- 
wadzonego do pamięci obrazu. Kserografu tańszego 
od powszechnie stosowanych olbrzymów, obdarzone- 
go na domiar wszystkiego możliwością przesyłania na 
odległość, dzięki połączeniu komputera 7 siecią telefo- 
niczną, tego, co leżało pod scannerem. 

Właśnie w ten sposób w Stanach Zjednoczonych 
rozpoczął się. obecnie rozpowszechniony nie tylko w 
Ameryce, ruch edytorów domowych pisemek kompute- 
rowych. Gazetek przesyłanych telefonicznymi łączami 
znajomym i przyjaciołom. Mikrokomputery zrewolucjo- 
nizowały także funkcjonujące do tej pory dzięki ksero- 
grafom miesięczniki hobbystyczne wydawane przez 
miłośników kotów, psów, starej broni, historii lotnictwa, 
antycznych samochodów, etc..., określane w Stanac. 
fi Ziednoczonych jako "non profit publications", czyli 
publikacje nie obliczone na zysk i utrzymujące się ze 
składek członkowskich czytelników. Pisma zapaleńców 
przechodziły więc stopniową elektronicz ną metamor- 
fozę. Aby nie być gołosłownym powiem, że śledziłem ją 
na przykładzie wydawanego od lat siedemdziesiątych 
w Kalifornii "Smali Air Forces Observcra" — czyli "Ob- 
serwatora Sił Lotniczych Małych Państw" — periodyku 
historyków-amatorów dziejów wojskowej awiacji wyda- 
wanego zrazu kserograficznie przez Jima Sandersa. 

Ze zdjęciami i rysunkami zamieszczanymi w książ- 
kach był jednak zawsze podstawowy problem — najle- 
piej pod scanner wchodziły pojedyncze, płaskie kartki. 
Ideałem byłoby wyrwanie ich choćby na chwilę z 
kopiowanego wydawnictwa, a potem powtórne 
wklejenie do całej reszty dzieła. Niestety, z oczy- 
wistych względów, takie operacje nie były możliwe 
w przypadku wielu cennych pożyczonych, czy też 
własnych książek. Aby udowodnić czytelnikom na 
czym polegała cała trudność powiem co się stanie, 
gdy spróbujemy dokonać kserograficznej odbitki 
strony cienkiej, klejonej grzbietowo broszury. Je- 
żeli rozłożymy ją całkowicie I spłaszczymy, pęknie 
spoiwo i strony rozsypią się niczym talia kart. Obe- 


rwiemy z całą pewnością od właściciela sprofano- 
wanego w ten sposób wydawnictwa. 

Cóż więc było robić? Należało skonstruować skan- 
ner nie niszczący delikatnych książek, a przenoszący 
do pamięci komputera zawarte w nich obrazy. Takie 
urządzenie pojawiło się właśnie na rynku amery- 
kańskim. Składa się z ręcznego czytnika obrazów 
opracowanego przez Japan Mitsumi Corporation, 
połączonego z interfejsem dającym się podłączyć 
do dowolnego komputera rodziny IBM, lub kompa- 
tybilnego z IBM, a produkowanym przez Diamond 
FSower Electric Instrument Co. z Sacramento w 
Kalifornii. Ta druga firma rozprowadza po terenie Sta- 
nów Zjednoczonych ow Handy Scanner HS-1000 licząc 
sobie w detalu 299 dolarów za całą instalację. 

Jak działa HS-1000? Plastykowe pudełeczko miesz- 
czące się w dłoni, przypominające mikrofon polowej ra- 
diostacji "czyta" podstawiane pod jego okienko szkice, 
fotografie, rysunki, fragmenty planów z powierzchni 
czasopism, czy książek i przesyła zapamiętany obraz 
do komputera. Ten wyświetla to, co odebrał na ekranie, 
a więc można powtórzyć zabieg zapamiętywania, ieśli 
nie jesteśmy zadowoleni z jego rezultatów. Dalej może- 
my z naszym obrazem robić wszystko na co pozwala 
edytorski program komputera — zmnie|szać, rozcią- 
gać, wkładać z boków Ścieśnianego tekstu. W miarę 
potrzeb i fantazji. 

Przysposabiając HS-1000 do operacji "czytania" 
nastawić musimy żądany kontrast oorazu, a następnie 
przejeżdżamy naszym ręcznym scannerem po obrazie, 
który chcemy przenieść do komputera. Zapamiętana 
zostanie ścieżka obrazu o wymiarach 2,5 cala (63,5 
mm) na 10 cali (254 mm). Jeżeli uważamy, iż to za 
mało, przesuwamy urządzenie nad pozostałą nie wczy- 
taną leszcze częścią obrazu, robiąc to tak długo, aż ca- 
łość znajdzie się na ekranie monitora. I teraz możemy 
całkowicie pewni swego, zacząć zabawę w domowego 
wydawcę. 

Tyle przyjemności dostarcza już teraz amerykań- 
skim komputerowym fanom i specjalistom spółka Dia- 
mond Flowers. Zapowiada wszakże coś jeszcze do- 
skonalszego już w tym roku. Podobno rozpoczęła 
badania systemu podręcznego scannera umożli- 
wiającego optyczne "wczytywanie" wydrukowane- 
go tekstu. Rynkowe wydanie testowanego prototy- 
pu ma zostać rzucone do sklepów jeszcze w 1988 
roku. O cenie nie ma na razie mowy. 


Wojciech Łuczak 


Seria bułgarskich komputerów „Pravec” wzięła swą nazwę od mia- 
sta położonego 70 km od Sofii, gdzie znajduje się centrum ich pro- 
dukcji. Prócz 15 nowoczesnych zakładów powstała szkoła zawodowa, 
jeden z wydziałów politechniki oraz instytut cybernetyki. 


PRAVEC 


Produkqa PC "Pravec", którą rozpo- 
częto w 1981 roku od ośmiobitowych mo- 
deli "domowych" 8D, profesjonalnych 8M, 
edukacyjnych 8A i — ostatnio — szesna- 
stobitowych "Pravec 16" osiągnąć ma w 
najbliższych latach poziom 100 tys. sztuk 
rocznie. 

— Po dwu latach produkcji kom- 
puterów 16 bitowych trudno mówić 
o jakimś szczególnym doświadcze- 
niu, ale jeśli chodzi o niezawodność 
nasze PC mieszczą się w światowym 
standardzie — twierdzi inż. BORISLAW 
KUJUMDZIJEW promujący z ramienia 
centrali handlu zagranicznego "lsotim- 
pex" bułgarskie komputery na rynkach 
zagranicznych. 

— Patrząc na to z handlowego 
punktu widzenia — kontynuuje jego 
kolega z centrali inż. SVETLOZAR GRI- 
GOROW — można powiedzieć, że 
nasi klienci nie narzekają na jakość 
zakupionego u nas sprzętu. Znaczy 
to bardzo wiele, bo przecież w RWPG 
jesteśmy pionierami w tej dziedzinie i 
nikt nie oczekiwał, że wszystko pójdzie 
jak z płatka. 

— Dochodząc do produkcji seryjnej 
jednostek 16 bitowych — wspomina inż 
Kujumdżijew — dokonaliśmy ogromne- 
go skoku naprzód. Nie stało się tak w 
ciągu roku czy dwóch. Bułgaria kon- 
centrowała się na elektronice od lat i, 
co jest szczególnie ważne — robiła to 
celowo i systematycznie. Te doświad- 
czenia stworzyły solidne podstawy 
naszych obecnych osiągnięć i spo- 


wodowały, że rezultaty nie mogły być 
inne. Dotyczy to w tym samym stopniu 
mikro- jak i minikomputerów oraz du- 
żych jednostek wraz z urządzeniami im 
towarzyszącymi. 

Drugim ośrodkiem produkcji mikro- 
komputerów są zakłady STO w Wlike 
Trnovo. Produkowany tam sprzęt to pro- 
fesjonalne 16 bitowe EC1831 i 1832. W 
ubiegłym roku zakłady te osiągnęły już 
planowaną zdolność produkcyjną — 1000 
sztuk kompletnych systemów. 

PRAVEC 8 

Komputery tej serii opierają się na 
8-bito wym procesorze Motorola 6502. 
Najprostsza wersja — 8D — przezna- 
czona jest do nauczania podstawowego 
(programowania]. Jako monitor może 
służyć ekran telewizora (wystarczając 
rozdzielczość 240 na 200 pkt.); pamięć 
zewnętrzna — kaseta. 

Bardziej zaawansowany typ 8M. 
zgodny z Apple II jest modelem szeroko 
rozpowszechnionym w bułgarskich szko- 
łach. Ponieważ produkcję tych modeli 
rozpoczęto w 1981 roku, oprogramowa- 
nie dostępne jest w dużym wyborze. W 
przypadku tego mikrokomputera i jego 
wersji edukacyjnej — 8A dostarcza się 
z zasady kompletny system z monitorem 
monochromatycznym, drukarką M80 oraz 
jedną stacją dysków. 

Dane techniczne: 

— mikroprocesor: Motorola 8502 

— pamięć ROM  12KB 

— pamięć RAM  64KB 

— pojemność 140 KB (modele 8M i 


8A) 

— tekst 24 wiersze po 40 lub 
80'znaków 

— grafika 280x192 pkt/cal, 8 
barw 

— system DOS 3.3, CP/M, 
UCSD-p operacyjny 

— język Basic, Assembler 
i makroassembler. 
Pascal, LOGO, For- 
tran, Cobol, Pilot. 

PRAVEC 16 


Występuje w dwu odmianach: PRA- 
VEC 16N z monitorem o rozdzielczości 
720 na 348 pkt/cal i przenośny PRAVEC 
16S z monitorem o przekąlnej 23 cm, któ- 
ry stanowi integralną część komputera. 

PRAVEC 16N występuje w czterech 
wersjach: 

a — jako terminal 

b— z 1 stacją dysków o poj. dyskietki 

320 do 360 KB 

c— z 2 stacjami dysków 

d— z jedną stacją dysków elastycz- 

nych i dyskiem twardym 10 MB 

Dane techniczne: 


— Mikroprocesor Intel 8088 

— Koprocesor Intel 8087 

— Zegar 4,77 MHz 

— RAM 256—640 KB 

— ROM 40KB 

— Tekst 25 wierszy 40 lub 80 
znaków 

— System PC-DOS, MS-DOS. 
CPM operacyjny 


/M-86,Concurrent, 


CP/M, USCD-p, UNIX 
apod. 
Basic, Pascal, Cobol, 
Fortran. 

PC EC 1831 i EC 1832 

Są najlepszymi wśród 16 bitowych 
produkowanych w Bułgarii. Zgodne z PO 
XT oba typy różnią się tym, że w modelu 
EC 1832 jedną ze stacji dysków zastępuje 
dysk twardy. 

Dane techniczne: 


— Języki 


— Mikroprocesor Intel 8088 

— Koprocesor Intel 8087 

— Zegar 4,77 MHz 

— RAM 128 do 640 KB 

— ROM 64 KB 

— Dysk twardy ES 5300/5508-10 MB 


— Dysk elastyczny ES 5088/5321 


— Tekst 25 rzędów; 40—80 
znaków 
— Grafika 640 x 200 _ pkt./cal 
monochr., 320 x 200 
pkt./cal barwny 
— System DOS-PK,  MIKROS 
operacyjny 86, 
DOS-P 
— Język Basic, Assembler, 
programowania  For- 
tran, Pascal, Cobol, 
— Interface RS 2320 (C2) 
opracował Pen. 
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WSZYSTKO DLA WSZYSTKICH 


WOJEWÓDZKIE 
PRZEDSIĘBIORSTWO 
HANDLU WEWNĘTRZNEGO 
ODDZIAŁ W TYCHACH 


IDEOBI 


Akces Bystem 


ul.Karola Marksa 169 
80-416 Gdańsk-wrzeszcz 


tel. 41-13-04 
00-639 Warszawa poleca: : ; 
Marszałkowska 27 Atari XLINXE | AE aleja ZMP 77 
tel. 253-786 Atari ST A 


— minikomputery 8-bito- 
we (Atari, Commodore, 
Schneider-Amstrad) 

— minikomputery 16-bitowe 
kompatybilne z IBM PC 

— drukarki 10" i 15" firm 
STAR, EPSON, AMSTRAD 

— magnetowidy 

— kamery video 

— anteny satelitarne 

— aparaturę  badawczo-na- 
ukową 


Commodore 16/116/+4 
Commodore 64/128 
IBM PC 


Komputery 

sprzęt peryferyjny 
oprogramowanie 
instrukcje 


POCZTĄ 
I NA MIEJSCU 


WSZYSTKIE PROGRAMY NA: 
ATARI c: 


SPECTRUM « TIMEX 


dla Atari .XL: 
rozszerzenie RAH do 256KB 
interfejsy do magnetofonu 
interfejsy Centronicz 


Zapewniamy o atrakcyjnych 
cenach. 


K-43 


W W M IE ARA AMA A_AA_R_ME_RĘ 7 
EEPEFIE KI | 


7 STUDIO KOMPUTEROWE 
UZYTKOWNICY ATARI XL | 
AWARIE sze; ATARI-BAJT 
duży kagbutefow TAKI © | ATARI © AMSTRAD 


COMMODORE © SPECTRUM 
AP YE 4 oferuje: 
programy użytkowe, 
edukacyjne, gry, opisy, 
interfejsy do magnetofonów 
i pióra świetlne — ATARI 

tel. 20-80-34 Warszawa 
kaloji gratis przy zamówieniu 


na tasmąch kasetowych oraz di skieti 
ECCE A orhacj pO 26 GCZENIU znaczka udziela: 


al: 22 Lipea 47 w | WETTNOŚ| 
62-300 URZEŚNIA j A 63-000 SRODA WLKP, 
śr_1 F 


"TEN BADAŃ | EKSPERTYZ 
INŻYNIERII SYSTEMÓW 


Polskiego Towarzystwa Cybernetycznego w Poznaniu organizuje kursy z zakresu 
użytkowania i oprogramowywania mikrokomputerów SPECTRUM + i IBM PC: 


skr.poczt.51 
92-105 
WARSZAWA 21 


BIURO 
USŁUG KOMPUTEROWYCH 


BONUS 


© sprzęt 
© oprogramowanie 
© literatura 
© materiały komputerowe 

— ATARI XE/XL/ST 

— AMSTRAD CPC/PCW/PC 

— IBM PC XT/AT 

— COMMODORE 64/128 
oraz 
© interfejsy do magnetofonów i 
drukarek Atari 
© Catridge Basic XL, XE, Action 
Warszawa 
AI. St. Zjednoczonych 69, pawilon 
C-4 (dawniej Grochowska 207) w 
godz. 11.00 — 19.00. 


« Kurs podstawowy dla kadry kierowniczej przedsiębiorstw 20 w godz. 
10.000 zł. 

. Użytkownik — operator mikrokomputera, 60 godz. 15.500 zł. 

. Programowanie w języku BASIC, 100 godz. 26.900 zł. 

. Projektowanie i oprogramowywanie systemów informatycznych w 
technologii dBASE III, 140 godz. 36.600 zł. 

Zajęcia odbywać się będą w Poznaniu. Terminy rozpoczęcia kursów podamy 

przed ich uruchomieniem. Zgłoszenia prosimy kierować pod adres: Ośrodek Ba- 

dań i Ekspertyz Inżynierii Systemów Polskiego Towarzystwa Cybernetycznego, 


ul. 28 Czerwca 231/239, 60-915 Poznań, budynek TASKO, tel. 32-12-41 (w 
godz. 9.30 — 11.30), telex 04133583. 


Przenoszenie programów z 
COMMODORE na IBM PC 
oferuje 
ZAKŁAD OPROGRAMOWANIA 


MINIKOMPUTERÓW 
UL. Krokusów 19 
41-400 MYSŁOWICE 
tel. 226-537 
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ATARI 520ST 


PROGRAMY 


tel. 32-87-80 
Warszawa 


Programy na ATARI 
cena 100-250 złotych 
Ryszard Andrzejewski 
56-370 kry wadedkowkia 
ul. Kołłątaja 4. 


Bew 


Dziękuję TV — Video, Kserokopiarki, 
Microcomputery Berlin Zachodni 30, 
Wurzburgerstr. 2, tel. 214-11-58 za do- 
starczone kalkulatory, układy scalone. 


SERWIS WIENCEK pole- 
ca swe usługi w zakresie 
naprawy komputerów: 
COMMODORE, ATARI, 
SPECTRUM. 

Katowice, 

ul. Ossowskiego 28/30 

tel. 549-779 


SAMI O SOBIE 


— W zeszłym roku "Złotą Dyskiet- 
kę BAJTKA" zdobył klub MERIZAP z 
Ostrowa Wielkopolskiego zrzeszony w 
Federacji. Czy i w tym roku przewidu- 
jesz podobny sukces? 

— Trudno mi przewidywać decyzję 
jury. Wiem jednak, że nasze kluby mają w 
tego typu wspótzawodnictwach wiele do 
pokazania. | niejeden jest tak dobry jak 
MERIZAP. 

— Działacie w ramach ZSMP. Czy 
tworzenie klubów komputerowych nie 
wygląda przypadkiem na próbę prze- 
kupienia młodych ludzi bardzo atrak- 
cyjnymi zabawkami? 

— Z pewnością nie o to nam chodzi. 
Człowiek zainteresowany informatyką tra- 
fia przecież do klubu komputerowego, a 
nie na zebranie koła i dopuszczenie go 
do sprzętu nie zależy od legitymacji na- 
szego Związku. Poza tym, do Federacji 
należy wiele klubów niezwiązanych z 
Organizacją. Utworzono ją przy ZSMP, 
ponieważ zgodnie z Ustawą o wynalaz- 
czości, właśnie w ramach Związku So- 
cjalistycznej Młodzieży Polskiej, działa 
Turniej Młodych Mistrzów Techniki, powo- 
łany do wspierania innowacyjnych, a więc 
i informatycznych pasji młodzieży. 

— Odwiedzając kluby komputero- 
we w całej Polsce zauważyłem, że każ- 
dy z nich jest nieco inny, każdy pracu- 
je w innych warunkach, jaki jest więc 
sens łączenia ich działań? 

— Kluby różnią się wprawdzie między 
sobą, problemy mają jednakże bardzo 
podobne. Brakuje wydawnictw książko- 
wych z informatyki, szczególnie dobrych 
i tanich podręczników. Ceny sprzętu, 
zwłaszcza klasy PC, wahają się nie- 
ustannie. Łatwo też kupić złom zamiast 
komputera czy dyskietek. Klubowiczom, 
tym bardziej ambitnym, brakuje dostępu 
do szkoleń na odpowiednim poziomie, 
kontaktów z najnowszymi programami itp. 
Dotyczy to w pierwszym rzędzie człon- 
ków klubów działających poza ośrodkami 
akademickimi. Nasza Federacja stara się 
trudności te rozwiązywać. Likwidacja ich 
siłami pojedynczego klubu nie jest moż- 
liwa. 

— Na co mogą z Waszej strony li- 
czyć kluby? 

— Na pomoc i zasoby Centralnego i 
Wojewódzkich Klubów Komputerowych, o 
czym już mówiliśmy. Mam tutaj na myśli 
przede wszystkim oprogramowanie oraz 
wszelką pomoc organizacyjną, w tym 
również prawną. | jeszcze jedna uwaga 
— pytasz na co mogą liczyć kluby — co 
sugeruje instytucjonalny charakter Fede- 
racji, która przecież jest raczej masowym, 
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społecznym ruchem. To istotna sprawa, 
ponieważ nasze możliwości w znacz- 
nym stopniu zależą od współdziałania i 
stopnia koordynacji wspólnych przedsię- 
wzięć. Od jednomyślności w określaniu 
i artykułowaniu jednakich dla wszystkich 
interesów. Ta sprawa ma zasadnicze 
znaczenie obecnie, gdy głównym proble- 
mem ruchu nie jest dostęp do ZX 81, a 
tworzenie banków informacji i dostęp do 
nich, nie kurs BASICa na MERITUM I, a 
nauka d'BASE III+ . Po prostu klub to dziś 
już nie tylko zabawa, a w coraz większym 
stopniu rzetelna nauka wykorzystania 
komputera w miejscu pracy czy w szko- 
le, co wymaga odpowiedniej organizacji, 
dużych środków i pewnej planowości w 
działaniu. | na umacnianie tych tendencji 
w Federacji, można bezsprzecznie liczyć. 


— Wydaliście już dwie pozycje w 
serii "Mikrokomputery", w ramach bi- 
blioteczki Powszechnego Ruchu Ini- 
cjatyw Innowacyjnych POLIN. Jakie 
macie zamierzenia na najbliższą przy- 
szłość? 

— Mamy przygotowane cztery następ- 
ne pozycje dotyczące języków programo- 
wania, programów użytkowych i metodyki 
pracy klubu komputerowego. W sumie na 
ten rok 12 tytułów. Mamy autorów i dru- 
karnię, brakuje nam tylko ... papieru. 

— Czy każdy z klubów należących 
do Federacji otrzymuje te pozycje? 

— Oczywiście, każdy z naszych klu- 
bów otrzymuje odpowiednią ich liczbę. Na 
razie nieodpłatnie. 

Redagujemy też pierwszą w Polsce 
"gazetę komputerową", w postaci progra- 
mu na ZX SPECTRUM. Jest ona emito- 
wana przez Polskie Radio, w audycji RA- 
DIOKOMPUTER, raz w miesiącu. 

— Jakie są Wasze plany na okres 
najbliższy i trochę dalszy? 

— Najważniejsze dla przyszłości ru- 
chu KK MMT jest posiedzenie Komitetu 
do Spraw Nauki i Postępu Technicznego, 
który w najbliższym czasie będzie rozpa- 
trywał problemy wychowania innowacyj- 
nego młodzieży, w tym również edukacji 
informatycznej prowadzonej przez Kluby 
Komputerowe Młodych Mistrzów Tech- 
niki. Jesteśmy w trakcie opracowywania 
materiału o naszych dokonaniach oraz 
potrzebach. 

Poza tym wyposażamy kluby woje- 
wódzkie. W ubiegłym roku zakupiliśmy 
130 mikrokomputerów Amstrad. W roku 
bieżącym, nadal będziemy nabywać dla 
klubów Amstrad'y, jak również większe 
ilości IBM'ów. Chcemy w kwietniu urucho- 
mić Centralny Klub Komputerowy. Będzie 
tam miejsce na wymianę oprogramowa- 
nia, kompletowanie literatury. Chcemy 
stworzyć bibliotekę, gdzie każdy będzie 
mógł nie tylko wziąć do ręki wydawnictwa 
krajowe i zagraniczne, ale także zrobić 
kopię ich fragmentów, zdobyć informa- 


KONKURS ŚWIĄTECZNY ROZSTRZYGNIĘTY! 


cje co warto kupić, gdzie, kiedy i za jaką 
cenę. 

Złożyliśmy zamówienie na opracowa- 
nie taniego modemu galwanicznego, któ- 
ry chcemy wytwarzać z przeznaczeniem 
dla naszych klubów. Obecnie testujemy 
prototyp. 

W marcu rozstrzygniemy drugą już 
edycję konkursu na najlepiej pracujący 
klub komputerowy. Nagrodą Główną jest 
tym razem IBM PC XT. To tyle jeżeli cho- 
dzi o najbliższą przyszłość. 

— W ubiegłym roku pośredniczyli- 
ście w zakupach sprzętu dla klubów. 
Wiem, że był to sprzęt bardzo tani. Czy 
nadal macie takie możliwości? 

— Udało nam się wówczas wynego- 
cjować duże obniżki cen i część naszych 
klubów zdążyła z tego skorzystać. Nieste- 
ty, w listopadzie, w związku ze zmianami 
na rynku, ceny sprzętu znacznie się pod- 
niosły. Sądzę jednak, że w niedługim cza- 
sie dojdziemy do porozumienia z jakąś 
firmą handlową i znów będziemy w stanie 
przedstawić naszym klubom atrakcyjną 
ofertę zakupów. Na razie negocjujemy. 

— Kluby Komputerowe Młodych 
Mistrzów Techniki, znajdują się w całej 
Polsce. Gdzie młody człowiek, zainte- 
resowany informatyką znaleźć może 
informacje o Waszych klubach, w jego 
mieście czy gminie? 

— Już niedługo — jak sam wiesz — 
rozpoczniemy ich prezentację na łamach 
BAJTKA. Niezależnie od tego, informa- 
cji takiej udzielają Wojewódzkie Biura 
TMMT, które mieszczą się przy Zarzą- 
dach Wojewódzkich ZSMP. Wystarczy 
więc wziąć do ręki książkę telefoniczną. 
Służę też swoim wykazem adresów pod 
telefonem 26 54 01 wew. 362 w Warsza- 
wie. 


Rozmawiał: 
Roman Poznański 


Już od dawna listonosz doręczający kore- 
spondencję do redakcji „Sztandaru Młodych” 
nie miał tyle pracy. Na ogłoszony przez nas w 
„Bajtku” z grudnia ub. roku Konkurs Świąteczny 
wpłynęło ponad 15 tys. odpowiedzi. 23 lutego br. 


przed kamerami „Teleexpresu” odbyło się loso- 
wanie nagród. Oto pełna lista szczęśliwców. 

Główną nagrodę komputer Atari 65XE z ma- 
gnetofonem wylosowała Bożena Potoczny z Oła- 
wy. 
Posiadaczami plecaków „Atari” stali się Woj- 
ciech Drwal ż Tarnowa, Małgorzata Nowak i Je- 
rzy Pieńkowski z Warszawy oraz Anna Strzyżew- 
ska z Góry Kalwarii. 

Kasety z programami wylosowali Stanisław 
Nezveda z Pragi, Adam Lipszyc z Michalina, To- 
masz Wilk z Katowic i Tomasz Oczkoś z Gorzo- 
wa Wielkopolskiego. 

Książki o tematyce komputerowej przypadły: 
Sobiesławowi Gabarze z Bydgoszczy, Piotrowi 
Guzkowi z Chełmna, Piotrowi Grzelakowi z Ło- 
dzi, Krzysztofowi Bartzowi z Opola Lubelskiego, 
Jakubowi Osińskiemu z Warszawy, Arkadiuszo- 
wi Baronowi z Rudzińca, Waldkowi Kozłowskie- 


mu z Elbląga, Krzysztofowi Wąchali z Lwówka 
Sląskiego, Juliuszowi Zajdzie z Wrocławia, Pio- 
trowi Kozłowskiemu z Białegostoku, Marlenie 
Władyczko z Gryfina, Mariuszowi Gruzie z War- 
szawy, Grzegorzowi Landsmanowi z Gdyni, Ma- 
ciejowi Knulowi z Łaska, Pawłowi Witkowskiemu 
z Warszawy, Robertowi Woźnieko- wi z Lubuska, 
Ireneuszowi Rogale z Gdańska, Jarosławowi 
Charcholisowi z Bartoszyc, Wojciechowi Wia- 
trowskiemu z Nidzicy i Krzysztofowi Kamińskie- 
mu z Wrocławia. 

Ci, którzy nie wylosowali żadnej nagrody 
mogą zawdzięczać to bądź nieprawidłowemu 
rozwiązaniu (hasłem konkursu było „Bajtek 
Twoim przyjacielem”) bądż... brakowi szczęścia. 
Może dopisze im ono przy rozwiązywaniu Kon- 
kursu Wielkanocnego. 


Triumfatorom gratulujemy! 
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SAMI O SOBIE 


ROBOT EDUKACYJNY 


MIGROROBOT-1 


Na przestrzeni ostatnich kilku lat obser- 
wowany jest szybki rozwój małych robotów 
zwanych robotami edukacyjnymi. Można 
wskazać dwie główne przyczyny tego rozwo- 
ju: — wzrost produkcji i zastosowań robotów 
ea — burzliwy rozwój tanich 

omputerów osobistych. Roboty przemysłowe 

wraz z oprzyrządowaniem są urządzeniami 
drogimi. Jednocześnie rosnąca szybko liczba 
zastosowań tych robotów sprawia, że wzrasta 
zapotrzebowanie na małe i znacznie tańsze 
roboty treningowe o zbliżonych cechach funk- 
cjonalnych. Roboty treningowe używane są w 
zakładach stosujących roboty do wstępnego 
przeszkolenia personelu, na uczelniach a 
także w szkołach. Urządzenia takie także 
stymulują studentów (uczniów) do prób z 
konstruowaniem innych, podobnych urzą- 
dzeń. Od czasu, gdy mikrokomputer można 
wbudować do niewielkich zabawek znala- 
zło się wielu hobbystów budujących własne 
kroczące maszyny, jeżdżące myszy, żółwie 
i inne inteligentne urządzenia. Tak narodziła 
się idea konkursów, łączących przyjemne z 
pożytecznym. 

Konkursom tym patronują poważne insty- 
tucje, takie jak IEEE. Zadaniem uczestników 
turnieju MIGROMOUSE jest skonstruowanie 
robota potrafiącego znaleźć najkrótszą drogę 
w labiryncie w ograniczonym czasie. Wymia- 
ry labiryntu są narzucone, w związku z tym 
mysz nie może być szersza i dłuższa niż 25 
cm. Dodatkowym utrudnieniem jest wyma- 
gania całkowitej niezależności. Każdy robot 
musi mieć własne zasilanie i napęd i musi być 
samosterowany. Turnieje tego typu rozgrywa- 
ne są od 1980 r. i obecnie najlepsze myszy 
dysponują czujnikami podczerwieni, radarem 
ultradźwiękowym, możliwością przyspieszeń 
na długich prostych (osiągają prędkość do 
3 m/sek.) i hamowania przed zakrętem. W 
tym turnieju byłoby ciężko wygrać, ale można 
spróbować w micro ping-ponga. Na razie wy- 
ow roboty, którym w ogolę udało się tra- 
ić w piłeczkę. Wszystkim zainteresowanym 
czytelnikom, chcącym brać udział w takich 
konkursach polecam szczegółową lekturę IN- 
FORMATYKI 1/86. 

Ale powróćmy do robotów edukacyjnych. 
Konfiguracja kinematyczna robota edukacyj- 
nego jest mniej lub bardziej zbliżona do kon- 
figuracji ludzkiej ręki. Typowy manipulator po- 
siada ot 5 stopni swobody, co zapewnia 
mu podobieństwo do robota przemysłowego. 
Główne różnice wystepują przy porówny- 
waniu wymiarów (kilkadziesiąt centymetrów 
— 1,5:2 m), a co za tym idzie przestrzeni ro- 
boczej, udźwigów (poniżej 1 kg — do 20 kg), 
dokładności i oczywiście ceny (kilkaset, kilka 
tysięcy dolarow — kilkadziesiąt tysięcy dola- 
rów). Podstawowym wymogiem przy budowie 
robota edukacyjnego jest uzyskanie możliwie 
niskiej ceny konstrukcji. Wymóg ten silnie 
rzuiute na parametry ruchu manipulatora, do- 
kładność pozycjonowania nie jest zbyt wygó- 
rowana (rzędu 1 mm), trudno również mówić 
o prawdziwej powtarzalności. 

Urządzeniem sterującym robotem może 
być dowolny komputer osobisty wyposażo- 
ny w standardowe wyjście równoległe lub 
szeregowe. Niekiedy, wraz z robotem, firmy 
oferują specjalizowane sterowniki zaopatrzo- 
ne w odpowiednie przyciski funkcyjne. Jako 
oprogramowanie podstawowe oferowane są 
rownież proste języki programowania robo- 
tów, w większości oparte o interpreter języka 
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BASIC lub kompilator języka FORTH. Niektó- 
re systemy są przystosowane do rozbudowy 
o układy wizyjne i posiadają nawet proste pro- 
cedury rozpoznawania obrazów. Istnieje kilka 
typów robotów edukacyjnych, które różnią się 
zdecydowanie budową od tych omawianych 
powyżej. Są to jeżdżące mechanizmy-żółwie. 
Niektóre z nich oprócz sterowanego mecha- 
nizmu jezdnego są wyposażone również w 
ramię prostego manipulatora. Kilka typów 
robotów edukacyjnych to po prostu plastiko- 
we zabawki o złożonych, mechanicznych lub 
mechaniczno-elektrycznych układach prze- 
niesienia napędów, sterowane za pomocą 
dźwigni (joystick). Obserwuje się, że bardziej 
zaawansowane konstrukcje robotów eduka- 
cyjnych (o lepszej powtarzalności ruchu i wyż- 
szej precyzji pozycjonowania) znajdują powoli 
zastosowania również w małych firmach prze- 
mysłowych. 

Przedstawiony na zdjęciu robot edukacyj- 
ny jest efektem pracy kilku osób. Autorem mo- 
delu, a następnie prototypu manipulatora jest 
Paweł Kuzan, absolwent wydziału...elektroni- 
ki! PW.Manipulator w zależności od wykona- 
nia posiada 5 stopni swobody (z możliwością 
przymocowania narzędzia-piórka, wiertarki) 
lub 4 stopnie swobody i sterowany chwytak 
Robot posiada napęd hydrauliczno-elek- 
tryczny (pompki o mocy 50W). Do pomiaru 
położenia wykorzystywane są potencjometry 
obrotowe. 

Układ sterowania robota jest autono- 
micznym mikrokomputerem, zbudowanym z 
użyciem procesora Z80A, pamięcią EPROM 
o pojemności 4 kb, pamięcią RAM 8kb, prze- 
twornikiem analogowo-cyfrowym (8 kanałów 
— rozdzielczość 8 bitów), układem do trans- 
misji szeregowej oraz układami sterowania 
silnikiem. Układ sterowania umożliwia na- 
uczenie sekwencji ruchu robota jak automa- 
tyczne odtwarzanie. Ponieważ jednak jest to 
urządzenie dydaktyczne, przeznaczone dla 
przyszłych użytkowników robotów a przede 
wszystkim dla przyszłych konstruktorów, dla- 
tego normalnie pracuje się z robotem w inny 
sposób. Autonomiczny sterownik łączony jest 
(złączem szeregowym) z nadrzędnym kom- 
puterem (w chwili obecnej gotowejest opro- 
gramowanie na IBM PC oraz na -MSM — fir- 
my IMPOL-1) i traktowany jest jak inteligentne 
urządzenie wejścia/wyjścia. Sterownik przyj- 
muje i wykonuje zdefiniowane makrorozkazy, 
takie jak: podaj stan robota i urządzeń wej- 
ściowych, podaj położenie robota, zapisz ste- 
rowanie, zapisz pozycję kroku i wykonaj krok, 
wczytaj program pracy oraz wczytaj algorytm 
sterujący. Mając tak bogaty zbiór makrorozka- 
zów pracująca osoba może w zależności od 
swoich umiejętnosci bardziej lub mniej przej- 
mować od komputera władzę nad robotem. W 
najprostszym przypadku komputer umożliwia 
zaprogramowanie robota (korzystając z wbu- 
dowanego menu), zapamiętanie nauczonego 
programu na dysku (i oczywiście odczytanie 
tego programu), wysłanie nauczonego pro- 
gramu do sterownika. a potem wciśnięcie 
START i już. Natomiast dla prawdziwych 
fachowców istnieje możliwość zmiany algo- 
rytmu sterowania albo przez bezpośrednie 
sterowanie robocikiem, albo przez przesłanie 
zmienionego algorytmu pracy do sterownika.: 


Andrzej Gogołewski 


LOGICAL DESIGN WORKS, INC. 


780 Montague Expwy., 
Suitę 403, San Jose, 
California 95131 
(408) 435-1445 
tlx: 294526 LDW UR 


520STM 

1040ST 

$F314 

SH204 

$M125 

$01224 
Zestawy: 
520STM + $F314 
520STM + $F314 + $M125 
104087 + $M125 $890,: 

10408T + $C1224 $1069,: 

Komputery posiadają klawiaturę w wersji angielskiej, 


Składanie zamówień: 


Prosimy o wypełnienie formularza ITA-629P licencji eksportowej i 
przesłanie ekspresem lotniczym wypełnionego formularza oraz kopii 
przekazu bankowego na adres Logical Design Works Incorp. Pie- 
niądze (przekazem telegraficznym) należy wpłacać na konto: 


BANK OF THE WEST. MILPITAS OFFICE. 
1360 CALAVERAS BOULEVARD 
MILPITAS. CALIFORNIA 95035. USA 
Account no: 22004317 


512 KB RAM. modulator TV PAL. 5.5MHz 
1024 KB RAM. wbudowany drive 720 KB 
dwustronny drive 720 KB 
20MBHardDisk 

Monochromatyczny monitor 

Kolorowy monitor RGB 


$509,, 
$649,: 


Do zamówienia należy doliczyć kwotę $28 pokrywająca koszty spe- 
dytora z Hamburga. 

Zamawiający otrzymuje sprzęt na adres domowy w ciągu 5-6 tygodni. 
Komputery objęte są roczną gwarancją — serwis gwarancyjny i po- 
gwarancyjny wykonuje doświadczona i autoryzowana przez ATARI 
firma: 


Przedsiębiorstwo Zagraniczne KAREN 
ul. Obrońców 23 

03-933 Warszawa 

tel. 17 84 10 

tlx 813948 kren pl 


Pod powyższym adresem mogą Państwo zasięgnąć szczegółowych 
informacji technicznych. 


WSZYSTKO DLA WSZYSTKICH 


ASCOM TECHNOLOGIES 
[FAR EAST) PTE LTD 


PWPO-T "Refleks" Sp. z o.o. informuje, 

że działa jako wyłączny przedstawiciel serwisowy na zasadzie zawartego kontraktu 
z ASCOM TECHNOLOGIES (FAR EAST) PTE LTD. Na zakupiony w tej firmie sprzęt 
wydawane jest w Polsce świadectwo jakości i udzielana jest roczna gwarancja, w cza- 
sie której funkcje gwaranta sprawuje na zasadzie wyłączności PWPOT "REFLEKS". 
Sprzęt zakupiony w ASCOM po odebraniu przesyłki przez użytkownika jest testowany 
i sprawdzany bezpłatnie w PWPOT "Refleks" Sp. z o.o. 


UŻYTKOWNIK OTRZYMUJE TYLKO DOBRY SPRZĘT! 


Ponadto "Refleks" udzieli Państwu wszelkich dodatkowych informacji zarówno handlo- 

wych, jak i technicznych (katalogi, cenniki itp.). 

Kontakt: Przedsiębiorstwo Wdrażania Postępu Organizacyjno-Technicznego 
"Refleks" Sp. z o.o. Dział Importu, 02-051 Warszawa, ul. Glogera 1 tel. 
(02) 659-20-41, (02) 659-39-22 tlx 817530 ref pl. 

Wysyłkowo z firmy ASCOM TECHNOLOGIES (FAR EAST) PTE LTD otrzymacie Pań- 

stwo sprzęt mikrokomputerowy wysokiej jakości i w krótkich terminach dostawy: 


Oferta po atrakcyjnych cenach: 

— kompletne zestawy mikrokomputerów PGC/XT 6/8/10 MHz, PC/AT 8/10/12 MHz, 
PC/38612/16/20 MHz oraz inne, jak np. mikrokomputery przenośne i najnowsze 
typy profesjonalnych mikrokomputerów, 

— pełny asortyment kart CSKD, wyposażenia i akcesoriów umożliwiających samo- 
dzielne zbudowanie mikrokomputera lub rozszerzenie zestawu już posiadanego 
(karty główne, grafiki, kontrolery, karty obsługi wejść/wyjść, kable, obudowy, kla- 
wiatury, zasilacze), 

— pełny asortyment urządzeń zewnętrznych, takich jak: monitory monochromatyczne 
i kolorowe (szeroka gama typów o różnej rozdzielczości), pamięci taśmowe, pa- 
mięci na miękkich dyskach i napędy dysków twardych (o bardzo dużej pojemności 
i krótkim czasie dostępu), różne typy drukarek firm: EPSON, CITIZEN, STAR, PA- 
NASONIC, Amstrad, różne typy ploterów i digitizerów, 

— nośniki magnetyczne, 

— inne wyposażenie w środki techniki biurowej, 

— urządzenia i przyrządy elektroniczne, 

— urządzenia techniki video, 

— elementy i podzespoły elektroniczne. 

ASCOM TECHNOLOGIES/FAR EAST/PTE LTD 
Republic of Singapore 
45 Genting 05-02 Genting Warhouse Complex Singapore UM 
1334 Republic of Singapore. 
Przedsiębiorstwo Wdrażania Postępu Organizacyjno-Technicznego 


nowa gwlazda 
stale: |(- 


Najwyższy poziom technologii japońskiej Funkcja „PAPER PARK”: możliwość stosowania 
pojedyńczych stron oraz papieru z perforacją. 


Szeroki wybór zestawów znaków: 8 różnych krojów wbudowanych w drukarkę i znaki 
ASCII/IBM; wersja Commodore C-64/128; znaki do- 
wolnie programowane. 


Łatwość użytkowania: Kilkanaście funkcji wybieranych za pomocą przyci- 
sków na obudowie. 


Szybkość druku: 120 lub 144 zn/sek w trybie standard; 30 lub 36 zn/ 
sek w trybie korespondencyjnym. 


Druk kolorowy: Wersja LC-10 colour, drukuje w 7 kolorach! 


Rewelacyjne ceny: LC-10 lub LC-10C (do C-64/128) — DM 450 
LC-10 colour lub LC-10C colour — DM 550 
plus transport: DM 40, kabel: DM 20. 


Pełna oferta: Oczywiście oferujemy Państwu pełną gamę druk- 
-arek Star łącznie z najnowszą drukarką laser- 
ową LS-08 (8 str/ min), 1 MB, kompatybilna z HP 
Laser Jet II) za DM 4500. 


SLQIFK 
Twoja drukarka 


ABC Computersystems ABC Data GmbH 
ABC Data Im- und Export GmbH Wittenbergplatz 3a Ditmar-Koel-Str. 13 
AugustastraBe 40. 5300 Bonn 2, RFN 1000 Berlin 30 2000 Hamburg 11 


tel. 0228/35.44.80,-90. telex 88.55.66 tel. 213.59.37 tel. 31.40.03 
||| 2ŹŹŹŹŻ(ŹMTSTS//////(/ ,  SSSZ,GS„,((C((CCSS Telex 181.365 Telex 21.66.002 


30 BAJTEK 4/88 


http://www.t2e.pl/reduksy 


TYLKO DLA PRZEDSZKOLAKÓW 


OSIEMNASTOKOŁOWIEĆ 


Cześć Maluchy! 


Kubuś Literka, dzielny poszukiwacz 
przygód i nasz stary przyjaciel został kie- 
rowcą wielkiej ciężarówki. Chyba każdy (a 
może także każda)-z Was marzy o tym, by 
zasiąść za kierownicą takiego osiemnasto- 
kołowca i wyruszyć przed siebie. Okazuje 
się jednak — przekonał się o tym Kubuś — 
że życie kierowcy nie składa się z samych 
tylko przyjemności. Czasem trzeba nieźle 
się nagłowić, jaki zabrać towar i jaką po- 
jechać trasą, aby przewieźć możliwie naj- 
więcej ładunków. 


Zasady gry są bardzo pro- 
ste. W pięciu miastach znaj- 
dują się magazyny z towarem. 
W każdym z magazynów cze- 
kają na transport do poszcze- 
gólnych miast cztery ładunki. 
Kubuś rozpoczyna pracę od 
pierwszego magazynu. Jego 
ciężarówka zabiera jednorazo- 
wo 3 ładunki. Może wyruszyć 
na trasę tylko siedem razy a 
WR HERZ równocześnie musi starać się 
Y dostarczyć do miejsca prze- 
znaczenia jak najwięcej ładun- 


ków. Za każdy z nich otrzymuje 


zapłatę w wysokości 100 bajto- 
dukatów. 
t 


Gum) 


PLANSZA) 
BRANIE_LADUNKU 
PLANSZA) 


£CFONTEC ZALADUNKU 


Pisanie naszego programu 
rozpoczniemy od rozszyfrowa- 
nia nazw zmiennych i tablic: 
pozycja — Określa, w któ- 
rym mieście znajduje się w tej 
chwili ciężarówka Kubusia. 


KONIEC)" 


KOMUNIKAT KOŃCOWY 


9 REM * deklaracja tablic i zmiennych * 
10 LET pozycja=l 

20 LET zarobek=0 

30 DIM magazyn (5,4) 

40 DIM ladunek (3) 

77 REM **rk*x* losowanie ladunku **r*kx 
100 FOR i=i TOS 

110 FOR j=l TD 4 

120 LET magazyn(i,j)=INT(RND(1)+5)+1 
130 IF magazyn(i,j)=i THEN GOTO 120 
140 NEXT j 

150 NEXT i 

157 REM **** glowna petla program **** 
160 FOR k=i TO 7 

170 GOSUB 1000 

177 REM **xx*x*x branie ladunku **Fk*kkx 
180 FOR i=1i TO 3 

170 IF ladunek(i)<>0 THEN GOTO 2970 
200 PRINT "co zabierasz"; 

210 INPUT ladunek(i) 

220 IF ladunek(i)=0 THEN GOTO 280 
230 FOR j=l TO 4 

240 1F 

magazyn (pozycja, jl=ladunek(i) THEN LET 
magazyn (pozycja, j)=0:60T0 280 

230 NEXT j 

260 LET ladunek(i)=0 

270 GOTO 170 

280 GOSUB 1000 

270 NEXT i 

277 REM **rtktkk wybor magazynu *tłkkkkkk 


zarobek — Suma bajtodukatów, które otrzymał Ku- 
buś za przewiezione ładunki. 

magazyn (i, j) — Tablica ta zawiera informacje, jakie 
ładunki czekają na Kubusia w poszczególnych mia- 
stach. Parametr i określa miasto a j numer ładunku. 
Jeśli np. magazyn (3,1) = 4 znaczy to, że w mieście 3 
pierwszy ładunek czeka na przewiezienie do miasta 
4. Wartość 0 oznacza, że ładunku już nie ma. 
ladunek (i) — Ta tablica zawiera informacje o ła- 
dunku umieszczonym na ciężarówce. Może także 
zawierać zera, które oznaczają puste miejsca. 

Teraz możemy już prześledzić działanie nasze- 
go programu. Z pewnością przyda nam się schemat 
blokowy. Pierwszą czynnością po rozpoczęciu pro- 
gramu oraz deklaracji zmiennych i tablic (linie 10-40) 
jest wylosowanie początkowego rozmieszczenia ła- 
dunków (linie 100-150). Za każdym razem następuje 
sprawdzenie, czy przypadkiem w którymś z maga- 
zynów nie został umieszczony ładunek przeznaczo- 
ny właśnie do tego magazynu (linia 130). 

Po zakończeniu losowania rozpoczyna się wła- 
ściwa część gry wykonywana w pętli siedmiokrotnie 
(linie 160-440). Na początek wyświetlana jest na 
ekranie plansza informująca o stanie gry. W naszym 
programie planszę drukuje osobny podprogram (li- 
nie 1000-1310). Następna czynność to załadunek 
samochodu (linie 180-290). Nie jest to proste. Kom- 
puter musi wiedzieć, ile pustych miejsc jest na sa- 
mochodzie Kubusia i w zależności od tego, tyle razy 
pytać o ładunek. Musi także wiedzieć, czy żądany 
przez grającego ładunek jest w magazynie i aktuali- 
zować dane o zawartości magazynów. Jeśli grający 
nie chce lub nie może zapełnić całego samochodu, 
na pytanie o ładunek odpowiada wprowadzając war- 
tość 0. Po każdej odpowiedzi wyświetlana jest nowa 
plansza. 

Samochód załadowany, pozostaje tylko decyzja, 
do którego miasta jedziemy (linie 300-320) i rusza- 
my w drogę. Krótki program przedstawiający jazdę 
ciężarówki (linie 330-400) z pewnością wiele zyska, 
gdy zmienicie go nieco wykorzystując indywidualne 
możliwości Waszych komputerów, np. definiowanie 


300 PRINT "dokad jedziesz"; 

310 INPUT pozycja 

320 IF pozycjażs UR pozycjaći UR 
pozycjaćINT(pozycja) THEN GOTO 500 
529 REM *kkkxkkkkx jazda *IERRREKEK 
530 FOR i=i TO 35 

SĄÓ GLS 

30 FOR j=l TD i 

360 PRINT " "; 

SIO NEXT j 

580 PRINT "Hin" 

570 FOR t=i TO 100:NEXT t 

400 NEXT i 

407 REM **** rozladunek i zarobek **kx 
410 FOR i=1 TO 3 

420 IF ladunek(i)=pozycja THEN LET 
ladunek (i)=0:LET zarobek=zarobek+100 
430 NEXT i 

44Q NEXT k 

450 CLS 

459 REM *r**x* komunikat koncowy **F**x 
460 PRINT "Zarobiles"; zarobek; 
"bajtodukatow. " 

470 END 

999 REM ****xkkkkk plansza tłkkkkkkkk 
1000 CLS5 
1010 PRINT 
1020 PRINT ": 


magazyn" ;pozycja; 
1050 PRINT E 
1040 PRINT 

1050 PRINT 


znaków graficznych, czy drukowanie w określonym 
miejscu ekranu. Będzie to pierwsza część Waszego 
dzisiejszego zadania domowego. 

Po dojechaniu na miejsce następuje rozładowa- 
nie ciężarówki i obliczenie zarobków Kubusia (linie 
410-430). Tu kończy się pętla, a więc powracamy 
na jej początek, chyba że przebiegamy ją już po raz 
siódmy. W takim przypadku komputer przechodzi do 
wyświetlenia komunikatu końcowego i program się 
kończy. 

A ja mam dla Was jeszcze jedną propozycję. 
Spróbujcie zmienić nasz program w taki sposób, 
aby można było wiele razy rozpoczynać grę od tej 
samej sytuacji. W tej chwili, za każdym razem jest 
ona losowana od nowa. 

Powodzenia i... szerokiej drogi życzy Wam 


Romek 


1060 FOR m=1 TO 5 
1070 IF ladunek(m)<>0 THEN PRINT "-- 


sx 
1080 NEXT m 
1070 PRINT 
1100 PRINT " 
1110 FOR m=1 TO 5 
1120 IF ladunek(m)<>0 THEN PRINT 
ladunekim);":"; 
1150 NEXT m 
1140 PRINT 
1150 PRINT " 
1160 PRINT " 
1170 PRINT 
1180 FOR m=i TOS 

PRINT " 

FOR n=i TO 4 

IF magazyn(m,n)<>0 THEN PRINT 


/H: z"; 


NEXT n 

PRINT 

PRINT "magazyn";m;"-:"3 

1250 FOR n=1 TO 4 

1260 IF maqazyn(m,n)<t>0 THEN PRINT 
magazyn(m,n)z":"3 

1270 NEXT n 

1280 PRINT 

1270 PRINT " 


1230 
1240 


1300 NEXT m 
1310 RETURN 
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GIEŁDA | PEWEX RFN 

BAJTKA | BALTONA | (śred.) 

(tys. zl) (USD) (DM) 
SINCLAIR 
ZX81 50 = 30 
ZX Spectrum 48 kB 100 115 60 
ZX Spectrum Plus 155 - 70 
ZX Spectrum 128 + 2 280 - 100 
Drukarka SEIKOSHA GP50S 110 - 40 
TIMEX 2048 160 146 = 
Joystick 9-11 - 10 
COMMODORE 
0-64 245 219 165 
0-128 315 299 220 
C-128D - = 310 
Amiga 1.2 mln = 450 
Magnetofon 1531 45 48 25 
Stacja dyskietek 1541 260 - 170 
Stacja dyskietek 1571 310 299 185 
Drukarka GP-500 210 = = 
Dyskietki 5 1/4 (Średnia jakość) | 0.9-1.0 3.5 0.4 


ATARI 


65 XE 175 125 65 
130 XE 260 199 105 
Stacja dyskietek 1050 220 187 110 
Drukarka 1029 250 199 = 
Atari 520 STM St. Dysk. 0.5Mb | 1.0 mln 798 360 
AMSTRAD 

464 z mon. monochromat. 320 = 400 
6128 z mon. monochromat. 495 = 750 
6128 z mon. kolor. 595 = 1000 
Dyskietki 3" 6 - 6-9 
PC 1512 SD MM 300 = 380 
PC 1512 SD CM 1,2-1,3 = 500 
POW 8256 580 = 290 


Zainteresowanie oprogramowaniem i literaturą 
fachową nie maleje. Ustaliła się też grupa osób po- 
siadających znakomite rozeznanie potrzeb i wszelkie 
nowości w polskojęzycznej wersji natychmiast poja- 
wiają się na giełdzie. I chociaż „dorosłe” wydawnic- 
twa proponują coraz ciekawsze pozycje książkowe, 
ciągle jeszcze nie są one konkurencyjne dla odbitek 
kserograficznych mizernej jakości, sprzedawanych 
po 25 zł za stronę. 

Miejmy nadzieję, że nowa dziedzina zastosowania 
techniki komputerowej, czyli Desk Top Publishing 
zrewolucjonizuje w niedalekiej przyszłości także pol- 
ski rynek wydawniczy. Posiadając mikrokomputer 
klasy PC i drukarkę laserową, będzie można nawet 
na własnym biurku opracować i wydrukować każdą 
publikację, jakością nie ustępującą profesjonalnemu 
składowi drukarskiemu. 

Póki co, Wydawnictwo Naukowo-Techniczne ko- 
rzysta ze składu IBM, dzięki czemu cykl wydawniczy 
skraca do 3-4 miesięcy. 

(gr) 


DANYCH 


Grzegorz Dudek — uczeń szkoły ponadpod- 
stawowej, lat 15. Posiada mikrokomputer Com- 
modore 16/116. Zainteresowania informatyka i 
elektronika. Proponuje wymianę gier oraz pro- 
gramów użytkowych. Adres: 44-100 Gliwice, ul. 
Lotników 87/29. 


Przemysław Sadoch, lat 13. Posiada ATARI 65 
XE, joystick, magnetofon XC-12. Zainteresowania: 
informatyka oraz matematyka. Oprogramowanie: 
programy matematyczne, muzyczne oraz gry. Pro- 
ponuje wymianę oprogramowania oraz doświad- 
czeń. Adres: 64-920 Piła, PI."Zwycięstwa 10/11. 


Rafał Okarma, uczeń lat 15. Posiada komputer 
IBM PC wraz z osprzętem firmowym. Oprogra- 
mowanie: programy użytkowe, prezentacyjne i 
gry. Zainteresowania: informatyka, programo- 
wanie. Pragnie nawiązać kontakt z posiadacza- 
mi komputerów tej marki, w celu wymiany do- 
świadczeń, literatury i oprogramowania. Adres: 
33-171 Pleśna 284, Tarnów. 


Mariusz Ferdyn, uczeń lat 14. Posiada mikro- 
komputer Commodore 64, magnetofon TURBO 
DATA. Proponuje wymianę programów użytko- 
wych oraz doświadczeń. Adres: 03-977 Warsza- 
wa, ul. Egipska 5 m 14. 


Rafał Gałązka, uczeń 12 lat. Posiada mikro- 
komputer Atari 800 XL, stację dysków 1050. 
Oprogramowanie: gry i programy użytkowe. Ad- 


SYSTEm 


res: 97-300 Piotrków Trybunalski, ul. Kostrom- 
ska 66 bl 22 m 10. 


Piotr Bilski, lat 26, lekarz. Mikrokomputer AMI- 
GA 500, monitor 1084, drukarka Star NL-10, 
stacja dysków 3,5”. Pragnie nawiązać kontakt z 
użytkownikami Amigi w celu wymiany doświad- 
czeń, oprogramowania oraz literatury Adres: 70- 
836 Szczecin, ul. Węgierska 5. 


Karol Augustyn, lat 18. Posiada mikrokompu- 
ter Amstrad CPC-464. Pragnie nawiązać kore- 
spondencję w celu wymiany doświadczeń oraz 
oprogramowania. Adres: 15-082 Białystok, ul. 
Nowotki 13/2 m 59. 


Ireneusz Niezgoda, lat 15. Posiada mikrokom- 
puter C-Plus 4. Proponuje wymianę oprogramo- 
wania i doświadczeń. Odpowie na każdy list za 
załączeniem znaczka pocztowego. Adres: 05- 
400 Otwock, ul. Batorego 36 m 18. 


Marcin Hawrylczup, lat 16. Jest posiadaczem 
ZX Spectrum 48 KB oraz Commodore 64. Ma 
dostęp do najnowszego oprogramowania na 
wyżej wymienione typy mikrokomputerów. Inte- 
resuje się informatyką i muzyką. Z posiadacza- 
mi tych mikrokomputerów proponuje wymianę 
oprogramowania oraz doświadczeń. Adres: 03- 
580 Wa-wa ul. Zamiejska 9 m 19. 


Jacek Cieślewicz, uczeń lat 15. Posiada Atari 
65 XE oraz magnetofon XC-12. Oprogramowa- 
nie: gry i programy użytkowe. Zainteresowania: 
elektronika, informatyka oraz wędkarstwo. Ad- 
res: 62-200 Gniezno, Oś. Wł.Łokietka 14 B/15. 


Fryderyk Badura, lat 12. Posiada mikrokompu- 
ter ZX Spectrum. Proponuje wymianę gier oraz 
programów użytkowych. Adres: 44-200 Rybnik, 
ul. Dworcowa 5/41. 


Przedsiębiorstwo Wielobranżowe „System” 
działa jako wyłączny przedstawiciel serwisowy firmy: 


MEGA 


KURFURSTENDAMM 202 1000 BERLIN 15 


Tel. 8825641 tlx 182888 MEGA 


KTORA DOSTARCZA SPRZĘT ELEKTRONICZNY WYSOKIEJ KLASY 
W TYM: PC/XT/AT/RT; 16 I 32 BITOWE, DRUKARKI, PLOTERY, DIGI- 
TIZERY, MAGNETOWIDY, DYSKIETKI, TASMY BARWIĄCE ITP. INFOR- 
MACJĘ TECHNICZNO-HANDLOWĄ (KATALOGI I CENNIKI) MOŻNA 


UZYSKAĆ W SIEDZIBIE FIRMY: 
"SYSTEM" 


WARSZAWA, UL. WOLSKA RÓG MŁYNARSKIEJ (PRZEJŚCIE POD- 


ZIEMNE OBOK PDT WOLA) 
TEL. 32-80-93 


tle 817819 pws pl 


[...] Mój tata kupił komputer o na- 
zwie COMMODORE 2001 PERSONAL 
ELECTRONIC TRANSLATOR. Podob- 
no jest to dobry komputer ale do biura, 
do jakichś obliczeń. [...] Pytałem w By- 
tomiu czy mógłbym dostać programy 
na kasetach magnetofonowych lecz 


nic z tego. [...] 
Zagubiony RAFAŁ 


Komputer o którym mowa zwany jest 
w skrócie PET i byt swoistym hitem firmy 
Commodore pod koniec lat 70-tych. Był 
to jeden z pierwszych komputerów prze- 
znaczonych właśnie do biur i zakładów 
pracy. Jego następcami były Commodo- 
re VIC-20, Commodore C128 oraz C-64. 
Programy do tego komputera są rzeczy- 
wiście trudnodostępne jako, że sprzęt 
ten zostat już wycofany z produkcji. Je- 
dynym źródłem mogą być stare czasopi- 
sma komputerowe (amerykańskie) z lat 
80—83, poza tym giełda, choć obawiam 
się, że ich zdobycie będzie dość kłopotli- 
we. PET nie jest kompatybilny z żadnym 
innym „dzisiejszym” komputerem Com- 
modore. 


Jesteśmy wraz z kolegą początkują- 
cymi użytkownikami C-128. Chcieliby- 
śmy dowiedzieć się w jaki najprostszy 
sposób można połączyć te dwa kom- 
putery bez pośrednictwa linii telefo- 
nicznej, tak aby możliwe było porozu- 
miewanie się między sobą (mieszkamy 
oddaleni od siebie o 7 pięter w pionie). 
Chodzi nam o to, aby sygnał emitowa- 
ny przez jeden komputer był odbierany 
zarówno na telewizorze nadającego 
jak i odbierającego- 

Paweł Kamiński, Panas Kamiński 
RSZAWA 


Połączenie takie w zasadzie jest nie- 
możliwe. Po pierwsze w parometrowej 
długości odcinku przewodu będą się 
indukowały różnego rodzaju zakłóce- 
nia, które w ekstremalnych przypadkach 
mogą doprowadzić do spalenia układów 
transmisyjnych i procesora. Po drugie 
jakiekolwiek uszkodzenie samego prze- 
wodu MUSI doprowadzić do spalenia 
bardzo drogich układów CIA. Połączenie 
takie może być natomiast realizowane 
bez przeszkód za pomocą modemów i 
programu teletransmisyjnego, obojętnie 
czy będzie to się odbywało poprzez zwy- 
kły przewód czy przez linię telefoniczną. 


Drogi bajlku! 


W tym ostatnim wypadku wymagana jest 
jednak uprzednia zgoda odpowiedniego 
Urzędu Telekomunikacyjnego oraz ho- 
mologacja modemów. 


Mam kilka pytań związanych z mi- 

krokomputerem ZX Spectrum: 

1.Czy istnieje syntezer mowy na ZX 
Spectrum? 

2. Gdzie można dostać w Polsce pa- 
pier do drukarek? 

3. Jaka gra na ZX Spectrum najlepiej 
symuluje jazdę samochodem? 

4. Czy «. dwa różne programy o na- 
zwie „GREAT ESCAPE”? 

5. Jak zmienić kolor rysowanych linii, 
punktów w programie ART STUDIO? 

6. Czy w programie ART STUDIO są 

opcje rysujące wycinki koła lub elip- 

sy? 


7. Jaki program na ZX Spectrum po- 
zwala na uzyskanie więcej niż 32 
znaków w wierszu? 

8. Jaki zakład w Polsce rozszerza pa- 
mięć RAM ZX Spectrum? 

9. Gdzie można kupić lub wypożyczyć 
opisywany na waszych łamach kom- 
pilator Pascala? 

10. Jak można przetłumaczyć program 
napisany w Basicu nad kod maszy- 
nowy? 

Arkadiusz Socha 
ul. J. Krasickiego 22/1 
57-402 Nowa Ruda 


Oto odpowiedzi na Twoje pytania: 

1.Program pozwalający syntezować 
dźwięki zbliżone do ludzkiej mowy na 
ZX Spectrum nazywa się LMOWA. 
„Wypowiedzenie” danego słowa moż- 
liwe jest poprzez LPRINT „słowo”. 


ZX SPECTRUM 


INSTRUKCJE 
OPISY 
LITERATURA 


Szkoły i Kluby — Zniżka 


Katalogi — Gratis 


Co piąty program — Gratis 


Wysyłka na cały kraj 


Wypożyczalnia programów 
D.H. „Sezam” Il p. g. 16.00-19.00 
00-849 Warszawa UPT 66, skr. p. 14. 


2. Papier do drukarek rozprowadzają fir- 
my zajmujące się sprzedażą kompu- 
terów I sprzętu peryferyjnego, głównie 
drukarek. Oprócz tego papier pojawia 
się czasem w CSH oraz na giełdach 
sprzętu komputerowego. 

3. Sporo jest gier symulacyjnych, na czo- 

ło w symulacjach samochodów wysu- 

wają się TURBO ESPRIT firmy Durell, 

POLE POSITION firmy Namco oraz 
FORMUŁA 1 firmy Mastertronic. 

Tak. Jeden z nich to Monty's Great 
Escape firmy Gremlin Graphics z 1985 
roku, drugi to opisywany w Bajtku 

Great Escape firmy Denton Designs z 
1986 roku. 

5. Po wybraniu z menu opcji ATTR otwie- 
ra się okno pozwalające na ustawie- 
nie koloru atramentu, tła, ramki oraz 
jasności, inwersji i nakładania. Kolor 
wybieramy wskazując strzałką odpo- 
wiedni kwadrat. 

.Spośród krzywych stożkowych ART 
STUDIO może rysować jedynie okrę- 
gi. Uzyskanie elipsy możliwe jest 
przez zmianę skali okna obejmujące- 
go wcześniej narysowany okrąg. 

7. Chcąc umieścić 64 znaki w wierszu 
bezpośrednio w języku Basic, użyj 
programu „64 kolumny tekstu” z Bajtka 
7/86. Istnieją programy (głównie edy- 
tory tekstów) pozwalające pisać i dru- 
kować w podobnej gęstości. Niektóre 
z nich to Poltasword, The Writer, Star 


R 


[o>) 


ap. 

. Nie mogę podać Ci adresów firm roz- 
szerzających pamięć ZX Spectrum — 
przejrzyj dokładnie ogłoszenia w Bajt- 
ku i prasie codziennej oraz w innych 
czasopismach informatycznych. 

9. Nie ma w Polsce legalnego źródła 

uzyskania jakiegokolwiek programu 


[oo] 


H-a rama 
ATARI i SPEL „TEELI 


STUDIO FHTFIEGIT 
skr. Ati ra 
SOSHOMIEC 


— koperta 
Znaczek g-20 


TANIO WYPOŻYCZYSZ W 


% ADI-LENDING % 


— na teren Dolnego Śląska 
— sprzęt komputerowy ATARI 
— na cały kraj — programy, 
literaturę na ATARI, AMSTRADA, 
COMMODORE 

INFORMACJE 
58-400 Kamienna Góra 
skr. pocztowa 73 g-24 


JAK REKLAMOWAĆ SIĘ W BAJTKU? 


Reklamy przyjmuje Młodzieżowa Agencja 
Wydawnicza (Redakcja Wydawnictw Po- 
radniczych i Reklamy), 04-028 Warszawa, 
Al. Stanów Zjednoczonych 53, pokój 313, 
tel. 10-56-82. Cena reklamy biało-czarnej 
wynosi 300 zł za 1 cm7. Do ceny podsta- 
wowej doliczane jest 30% za dodatkowy 
kolor i 100% w przypadku reklamy wielo- 
barwnej. Ogłoszenie drobne kosztuje 200 
zł za jedno słowo. 


na Spectrum (z wyjątkiem, oczywi- 
ście, rodzimych wydawnictw typu 
KAW). Jedyną możliwością są giełdy 
komputerowe i kramiki z programami. 
10. Istnieje kilka kompilatorów tłumaczą- 
cych program w Basic-u na pseudo 
kod maszynowy, jak na przykład FP 
48K, BLAST czy TOBOS. Skompilo- 
wany program działa około 50 razy 
Szybciej. A czy nie lepiej napisać go 
od razu w języku maszynowym przy 
użyciu assemblera np. GENS 3M21? 


Przepisałem program  „Turbo-Co- 
py” z „Bajtka-Atari”. Po uruchomieniu 
przez RUN pojawia się raport „ERROR 
- BAD LINE 40”. Sprawdzałem, linia 40 
jest przepisana prawidłowo. Proszę o 
R RĘ prawidłowego brzmienia linii 
40. 


Tomasz Rowicki 


Istnieją dwa sposoby rozwiązania Pań- 
skiego problemu. Pierwszym jest wymia- 
na modułu zasilającego komputera na 
podobny moduł przeznaczony do euro- 
pejskich wersji POW. Wymaga to oczywi- 
ście zakupu takiego modułu. Drugim jest 
wykonanie transformatora 220/110 V, co 
pozwoliłoby na niedokonywanie zmian 
w samym komputerze. W każdym wypad- 
ku wymaga to współpracy ze specjalistą 
z dziedziny elektrotechniki, wraz z doko- 
naniem dokładnej analizy obciążenia pro- 
jektowanego transformatora. 

Komputer wybrał Pan nieźle. Dla ma- 
szyn serii POW pojawiły się również gry, 
jakkolwiek nie w oszałamiającej ilości. 

Z literaturą może Pan mieć sporo kło- 
potu. Tłumaczeń materiałów zagranicz- 
nych i pewnej ilości własnych, polskich 
opracowań poszukiwać można w firmach 
prywatnych, zajmujących się dystrybucją 
oprogramowania. Sprawę częściowo uła- 
twia fakt, że Amstrad POW pracuje w sys- 
temie CP/M, ale jest szereg programów 
przeznaczonych tylko dla PÓW — i tu 
zaczynają się trudności. 


Od niedawna posiadam Atari 800XL. 
Przez ten krótki czas zorientowałem 
się już, jak wiele niedogodności niesie 
ze sobą programowanie w języku Atari 
Rpa Taśmowe programy z językami 

trudno dostępne i wgrywają się zbyt 
a ugo, na stację dysków zaś mnie nie 
stać. W związku z tym proszę o odpo- 
wiedzi na następujące pytania: 

1. Czy istnieją cartridge z yami 

programowania? Z jakimi: 

2. yaka jest cena jednego cartridge- 


3. ka do CBE a jest dołączana 
jakaś literatura? 

4. Czy cartridge można nabyć w Pe- 
wexie? Czy literatura jest wów- 
czas w języku polskim? 

5. Które z dostępnych na cartridge 
ach języków są godne polecenia! 
(nazwisko i adres do wiadomości 

redakcji) 


Wiele języków dostępnych na Atari ma 
wersje na cartridge'ach. Najważniejsze 
z nich to: Basic XL, Basic XE, Actionl, 
LOGO, Macroassembler 65, Assembler 
Editor. Pierwsze dwa nawet nie mają in- 
nych wersji. Ceny cartridge'ów są różne 
— w Pewexie kosztują one około 20$, aw 
prywatnych i polonijnych firmach oraz na 
giełdzie około 25—40 tys. zł. W Pewexie 
cartridge sprzedawane są wraz z orygi- 
nalnymi instrukcjami w języku angielskim, 
natomiast dostępne za złotówki mają 
zwykłe tłumaczenia tych instrukcji (nie za- 
wsze dobrej jakości). Trudno jest polecać 
któryś z tych języków. Wybór jest zależny 
od umiejętności programowania, rodzaju 
programu oraz od upodobań programisty. 
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NIE TYLKO KOMPUTERY 


apończycy tego urządzenia nie wynaleźli. Z 


ewności 
umiejętność 
telefoniczn 


jednak doprowadzili 
osługiwania si 
jest w tym kraju sprzętem tak 


do perfekcji 
nim. Aparat 


NCEeeTZYTNINY ELULIENECTZANĘSYCYJNYZANZUNE! 


osiłków. Nic wiec wt 


m dziwnego, że staraj 


się udoskonalać go jak się tylko da. 


Zółte, zielone, czerwone, niebie- 
skie. Zainstalowane są na ulicach 
Toyko dosłownie co krok. Pojedyn- 
cze lub zgrupowane po kilka i kil- 
kanaście. Wydawałoby się, że w tej 
sytuacji nie może być żadnych pro- 
blemów ze znalezieniem wolnego 
automatu. Nic bardziej błędnego. Ja- 
pończycy pokochali telefon i rozmo- 
wy prowadzone przezeń tak samo, i 
tak szybko, jak pokochali wiele rze- 
czy rodem ze świata zachodniego. 
Tylko dzięki ilości automatów nie 
musimy pokonywać kilkuset metrów 
w poszukiwaniu wolnego. A kiedy już 
złapiemy za słuchawkę... 

Telefony instalowane na ulicach są 
dwojakiego rodzaju. Miejskie służące 
do krótkich trzyminutowych rozmów 
i międzymiastowe. Owe trzy minuty 
kosztują 10 yenów i jest to najtańsza 
usługa, jaką można w Japonii spo- 
tkać. Oczywiście wrzucenie następ- 
nej monety przedłuża nam możliwość 
dialogu o następne trzy minuty. Au- 
tomat międzymiastowy kosztuje już 
100 yenów. Najczęściej spotkać moż- 
na połączenie tych dwóch systemów. 
Żądane połączenie otrzymujemy po 
wrzuceniu odpowiedniej monety. 

Specyficzna miłość do rozmów 


TELEFONICZNE 


SZALEŃSTWO 


(Korespondencja 
z Japonii) 


telefonicznych zainspirowała racjo- 
nalizatorów. Myśleli, myśleli i wymy- 
Ślili automat, do którego nie wrzuca 
się monet. W zasadzie nie różni się 
on niczym od normalnego. Połącze- 
nie z abonamentem otrzymujemy po 
włożeniu karty, na której zakodowa- 
no odpowiednią ilość tzw. jednostek 
rozmówniczych. Zasada posługiwa- 
nia się tym cudeńkiem jest bardzo 
prosta. Podnosimy słuchawkę. Do 
otworu wsuwamy kartę telefoniczną 
i na malutkim monitorze zostaje wy- 
świetlona liczba jednostek, która po- 
została jeszcze na karcie. Wykręca- 
my żądany numer i nie pozostaje nic 
innego jak gadać. W ciągu całej roz- 
mowy możemy obserwować „ucieka- 
jące” cyferki. Kiedy liczba zbliża się 
do zera, to albo kończymy miły dia- 
log, albo wkładamy nową kartę. I tak 
bez końca. Po odłożeniu słuchawki 
przenikliwy sygnał przypomina nam, 
abyśmy nie zapomnieli zabrać karty, 
która „wypływa” właśnie z automatu. 
Przy okazji ruszyła cała machina 
produkująca karty telefoniczne. Do 
wyboru i do koloru. Zamierzamy uci- 
nać sobie długie pogaduszki kupuje- 
my taką z tysiącem jednostek. Jeżeli 
nie należymy do wybitnych gadułów 


wystarczą nam takie z pięćdziesię- 
cioma (najmniejsza ilość), stoma, stu 
pięćdziesięcioma. I każda w innym, 
niepowtarzalnym wzorze i kolorze. 
A że Japończycy uwielbiają gadać 
przez telefon przekonałem się, kiedy 
chciałem zadzwonić do Polski i zło- 
żyć życzenia noworoczne (a może to 
zrobić tylko za pomocą automatu na 
karty ze względu na wysokość opła- 
ty za rozmowę). Czekałem prawie 30 
minut, aż szczebiocząca Japoneczka 
opowie wszystkie ploteczki swojej 
znajomej. 

O tym, jak Japończycy potrafią 
ułatwić sobie swoje „telefoniczne ży- 
cie” mogłem przekonać się jeszcze 
nie jeden raz. Ot, chociaż w czasie 
pobytu u znajomego. Zadzwonił te- 
lefon. Kolega podniósł słuchawkę 
i rozmawiał ok. pięciu minut. Na- 


Oryginalna karta telefoniczna. Dziurki 
obok cyferek określających ilość jed- 
nostek rozmówniczych informują o ak- 
tualnym stanie posiadania. 


Japończyk może nie mieć przy sobie 
drobnych monet 100 lub 10 yenowych. 
Zawsze jednak ma kartę telefoniczną. 
Tuż pod otworem wrzutowym znajduje 
się monitorek, który wyświetla aktualny 
stan posiadania. 


gle słyszę: „Poczekaj, ktoś do mnie 
dzwoni”. Nacisnął guzik na aparacie 
i... rozmawia z kimś innym. Po pew- 
nym czasie powraca do przerwane- 
go dialogu. Kiedyodłożył słuchawkę 
poprosiłem o wyjaśnienia. Okazało 
się, że może w każdym momencie 
przerwać rozmowę i uzyskać nowe 
połączenie nie przerywając poprzed- 
niego. Mało tego, w ten sam sposób 
na jednej linii może ze sobą rozma- 
wiać i kilka osób. Ot, takatelefoniczna 
konferencja. 

Największą frajdę sprawiło mi 
jednak jednoczesne rozmawianie i 
widzenie mojego rozmówcy. Aparat 
telefoniczny z podłączonym do nie- 
go monitorem nie należy już do no- 
wości. Można go normalnie kupić w 
sklepie i zainstalować w domu. Pod- 
stawowym warunkiem oglądania roz- 
mówcy jest jednak posiadanie przez 
niego podobnego urządzenia. Nie są 
one jeszcze tak popularne jak zwykłe, 
standardowe aparaty. Jedyną więc 
możliwość zobaczenia rozmówcy na 
małym ekraniku miałem w sklepie, w 
którym bez żadnych problemów uda- 
ło nam się uciąć kilkuminutową roz- 
mowę na odległość trzech metrów. 
Zabawa była jednak przednia. 

Kiedy siedzieliśmy wieczorem w 
domu znajomych Japończyków i opo- 
wiadaliśmy o wrażeniach minionego 
dnia, nagle rozległ się głos: „Proszę 
podnieść słuchawkę, proszę pod- 
nieść słuchawkę”. W ten sposób te- 
lefon dawał znać, że ktoś pilnie chce 
się połączyć z gospodarzami. Pani 
domu podniosła słuchawkę i wydała 
okrzyk radości, gdy się dowiedziała, 
kto dzwoni. A jej mąż krótko podsu- 
mował: „Mamy godzinę z głowy”. Nie 
wiele się pomylił. 


Jerzy Wasilewski 
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Seria „Reduks” ma na celu 
przetworzenie - pełne Zzdigi- 
talizowanie prasy komputer- 
owej z początków okresu in- 
formatyzacji naszego kraju. 


W odróżnieniu od plików w formacie djvu i cbr 
gdzie format papierowy jest tylko zeskanowany 
i połączony w jeden dokument, reduks polega 
na ponownym przełamaniu dokumentu, 
wraz z ponowną obróbką graficzną - często 
z ich ponowną kreacją. Tam gdzie to możliwe 
zachowana jest grafika z pierwowzoru, jednak 
jeśli materiał jest zbyt złej jakości - zostaje on 
podmieniony (oczywiście jeśli jest dostępny) na 
równoważny. Jeżeli uda się odnaleźć błąd w za- 
mieszczonych listingach są one poprawiane tak, 
aby mogły zostać uruchomione na emulatorach 
lub mikrokomputerach. 


Rozpocząłem ten cykl od „Bajtków”, jednak 
mam nadzieję, że uda mi się wzbogacić kolekcję 
zdigitalizowanych i ponownie przełamanych peri- 
odyków także o inne wążne tytuły z lat ubiegłych, 
o których powoli zapominamy, a bez których 
współczesny obraz komputeryzacji wyglądałby 
zgoła inaczej. 


Wydania „Reduksowe” są bezpłatne, nie 
roszczę sobie żadnych praw do zawartości 
przetwarzanych magazynów, jednak ilość 
czasu i pracy jaką wkładam aby mogły 
one trafić w Twoje ręce jest na tyle spora, 
że pozwolę sobie napomknąć iż możesz 
wesprzeć mnie przekazując dotację w do- 
wolnej wysokości. 


Jeśli posiadasz materiały fotograficzne lub 
edytorskie, które są lepszej jakości niż prezen- 
towane w numerach, daj znać. 


U ramach walnego czasu odtwarzam 
stare magazyny komputerowe i prowadzę 
serwis emulacyjny tryżemu. Jeżeli uważasz, 
że mo ja publiczna działalność możesz 
postawić mi kawę, a kawę lubię;) 


G 


https://buycoffee.to/t2e 


Osoby, które wspiera ją serwis datkami* 
ma ją dostęp do reduksów w wysokiej 
rozdzielczości z usuniętymi reklamami. 


W zależności od wysokości datku każdy otrzymuje czasowy dostęp do reduksów w pełnej 
rozdzielczości na miesiąc, 3 miesiące lub 6 miesięcy. 
Osoby, które aktywnie wspierają projekt mają dostęp nieograniczony. 


WSZYSTKO DLA WSZYSTKICH 


AUTORYZOWANY SKLEP 
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TUTAJ SĄ TWOJE JEANSY! 


Jeans24h.pl - autoryzowany sklep online. Znajdziesz u nas 
ubrania znanych na całym świecie producentów odzieży dżin- 
sowej - Lee, Wrangler, Mustang Jeans, Cross Jeans, Tom Tailor. 
Kupując u nas odzież tych marek masz pewność iż pochodzą 


one bezpośrednio od producenta, są oryginalne i w I gatunku. 


www.jeans24h.pl 


Lee ust" Wrangler 


SBB -ROSS JEANS GID TOM TAILOR 


